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READ DEFECT DATA (12) COMIMANG ...csccssssscsscssssuscascuvevsssvesssevecessuvecssevecoosusaseusoseevecossusnseevecseusessesvecdssuienseevetsseussisrovets 162 
READ DEFECT DATA (12) parameter data ....ssssssssssssssssssescssseecessseessnseeessssesesuseesssssessssnesesueesssusesssuseessnssessnnsesssntees 163 
READ: LONG (10): COrm ia ind ssciccccccsccsicssctecsisacscstsadcsecsascvesdcsas csscvetesce det wicsussdse iavecstaitesstecscs2idosesssscvevanceustsacasstesssesteesvsavesiss 
READ LONG (16) commana .... 

REASSIGN BLOCKS command 

REASSIGN BLOCKS parameter list ........cssssssssssscsssecsssccssecsssscsssccsnseccssccsssecsuseesssecsnsecsssecsusesseecesscessscessscceasecssneeeasecssseestees 168 
REASSIGN BLOCKS short parameter list header on... sesssssscsssesssssccsscecssecsssccessecsssecssscesnscessescescesssccessecssneceseecsaseessaes 168 
REASSIGN BLOCKS long parameter list hEader ou... essssssesessseecesssecesstecesnssesssssecesuseesssssessssseessueesssuneesenssessnsseeesusees 168 
RECEIVE DIAGNOSTIC RESULTS command .... 

DiaQmOStic Data Byte sscisscccsscecissiccsssseatccssnsicissasesteesossieassoisecoedanss casessesisessudendeaniestvetusdandseseossucdbeisdicobsesocadesienteasoesiatslines 
DidGMOStic: FAUIt:COCES: 5.ccscssscssssscsnsssesscsscssnssccsrssssssnsssenesssdsnsneasseseseensnedersnederseensrsusenrsdatprsvedgersdegprossegsnasecnsessessesssessansennavecs 
RELEASE (6): COMMANG’ secccsscccsssssccssidecdesscesesssccssaseatsteesei0ie3cousssdcsros0dieisesovebuvéssesecosdesudsios covonstbevesecsossdedstsedesuncacedebedéosassasevavei 
RELEASE (10) Co imitiaind iiccss sccecsesccvicsavad Se cadscstnsdcGo dsc Rebs aegis aiacSacVaceauad Aa Gi acslatae ads cas ssaasaveeasuevaiedbatasctassdvsvestesbeeeageeees 
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RELEASE (10) parameter list ........c.scssssssssssssssssssssesssessscsssesssccssessuesssssescsssessucsssecsucsssessucsuscesscssssesscsussesscsseseseecascensessseeseeess 
REPORT IDENTIFYING INFORMATION COMIMANG .....csssssssssssssessssccsscecssccessccessecsssecssscesnscesssceesecssseceanecssneceseecssseestees 
INFORMATION TYPE .......sssscssscssssccsseccssccerscccssecsssccessccesnecesseesssees 

REPORT IDENTIFYING INFORMATION parameter data 
REPORT IDENTIFYING INFORMATION SUPPORTED parameter data ........cssssssscsssecsssecssecsseesseesssccssscceseecsseeesees 178 
Identifying Information descriptor si 
REPORTLUNS: COMMAND sess casts czesssrcosssctascssnssansastesssecaertta vedas intetecradeneaaeaustadewenndavinicartaweiitd anbtetiascattaecdevaceaeaetten 
SELECT: REPORT fig hGh x; .csssscssvazsssacesscccusscssstatachacsctedaieatwane dvsavactoavybil cvs tssutceonbechusnsectactsasdesyactoa see Wansvaveblavessesetuestuabccuynnsesveed 
REPORT LUNS parameter data format .........csssssecsseeesseees 
REPORT SUPPORTED OPERATION CODES command 
REPORTING OPTIONS fielO .........ssssssssccssecsssecsssccsnsccsnscessecessecctsscesssccssccesscccsuscessecsssecsnsecenscessscessseceuscessecesssecsasecsnseeesseessaes 
All_commands parameter data : 
COMMAN CeScriptor FOrMAL ......cesccssecsssecsssecsssccssesesseccssescesecesseccesecesueccsuecssuscessecsssecsssecsaseesseesasecsssceeseecsseeeeaeessneeesseetens 
CLEP iE 1 Chara sce sesnes ect aet vicars cxcecteceaseeceveatncetesMscaaysvtas cosy casa vias uatscavxsstestusiearvastentustdstts.centeateastestantesterthsteteneaatedeaectsapieacceemts 
One_command parameter data .... iis 
SUP POETS] sssssse Secsscsessssssdssessazssscsosssscasseonstensesssesseeddesvaassescatesansbsnsdsnsnbsnsasosndensezendancdzenaaistuaati daaiviaanesdasnstusnsoascndsscnssenastecieits 
Command timeouts Aescriptor fOrMAL ....sssccsescssescrseecsseecsseccssccsseeccscecsnscessecessecessecesseessscesaseesseeceseeesseeceseeesaeeesseeeets 
Command timeout descriptor COMMAND SPECIFIC field usage in this manual ss 
REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS COMMMANG .......esessssscsssscsseccsstsesseectseecessecsseecsneessneeesaes 
REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS parameter data .......scsssssscssscssecssseccsccsssecsnecesneeesees 
REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS extended parameter data a 
REPORT. TIMESTAMP Command esssissesssssssossssesisssian céesssssesusscavvaccscossavssntastedeasiutesssovitosésbuiessstanstedsssivebsecartaosésesvassarbaséovenes 
REPORT TIMESTAMP parameter data format .....ccsssscssssssssccssssssssecsseecsssccsseecsnsessssecsssessnscessescsscessscceanecssneceaecssseessaes 
REQUEST SENSE command ss 
RESERVE(6) Ori inne tes ccsscciccvssccccsccsicescacussessastvascsc escvasscsas catevsecass at vavsncidsse sal sastsusevid vacwiesdossssdavsvesdebateaceastesasekeasssateoaies 
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RESERVE (10) ID only parameter list sé 
REZERO UNIT COMMANA (OTN) cescceccsccscssssssssssssssessesscsssssssesscsscsssssssssssssssessessssesssssessssessessessessssessessessssessessssssssesssssessesseees 
SANITIZE COMMANA (48h) uiscsccsccssscsscsscssessessessessescsssssessessesscssssssscssesssssssssscssessssssssesssesssssssssssssesssssessesssessssssssessssssssesssees 
SANITIZE service action codes 
OVERWRITE service action parameter list 
TEST Fi@l hc, ciesssccscscsccstescesssescondsactasbesdaatbaceass chastesadessscesekscctsbiadssalotcanbsacandacksgensdalouceeuacd cutest teas suebsusibbuidssibansaatbacennbeasstssadtbodss 
SECURITY PROTOCOL IN command 
SECURITY PROTOCOL field in SECURITY PROTOCOL IN command 
SECURITY PROTOCOL SPECIFIC field for SECURITY PROTOCOL IN protocol OOK ou....e.ssesssssesccssecsseecsseeeseees 
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Supported security protocols SECURITY PROTOCOL IN parameter data... esessssssssssessseesseecsecsseecseeesnsees 207 
Certificate data SECURITY PROTOCOL IN parameter data 
Certificate data SECURITY PROTOCOL IN parameter data 
Compliance descriptor fOrmat .....c.cssccssecsssecssseccsscccsscessescssccessccsssscesueecsuccesuscesseccssecsssccssscesaeesseecsascesseeesseeceaceesneessnseests 
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FIPS 140 Compliance GeSCrIPtOr ou... esssssscssssccssecssssccssecsssccssscessccssceessscesssccessecsuccesnscessscessecsnsccesseesuscessseceasecssueceseecsaseessaes 
REVISION SVC seess czecccsccessscasetscatssigeewsiec teat teshcescatascgecscatcasec decks ceeds tevecradenetieeate adc aacrecasth eet feaaedl dintecauncttencareran 
SECURITY PROTOCOL OUT COMIMANG ......ssssssssssssscsseesssecessccecsccesscecsnccssuccessecsssecssscssnscessscesssecssccesseeesneessueessneeesneeessees 
SECURITY PROTOCOL field in SECURITY PROTOCOL OUT COMMANG ......csessssescsseccsseccescccsscessscceseeceseecsneeesssees 213 
SEEK command (OBh) 
SEEK command (2Bh) 
SEND DIAGNOSTIC COMMANA ....eesessssssscsssecsseecsseecsssecssscessecesseccesccesscecanecssuccesnecessecesseesnscesssessusecsucsesseessueessneessneeesneeesssees 217 
SELFATEST:\GODE PIS sais castssaiesevsatesiucsisetevcadevsaccudetssendtiuenduadsayescusvesiisesvevdevebcanvectadedevubestavcayesquayectuasdsaussysbduabesaseploveensetbaavele 217 
SET IDENTIFYING INFORMATION COMmMAN ......ssssssssssssecsesccsssccsscccesccessecensccsssecsnscessscessesensecssscesscessueessneessneeesneeesaees 219 
INFORMATION TYPE Code list .......sssssssssccsscccsssccssecsssecsssccssscessscessscccsccesseccsusessuscesnsesssscesscesuscesssccssseessceesaseceasecsnsecssseessses 220 
SET IDENTIFYING INFORMATION parameter list .........ssscsssscsssscssccsscccsscccssccessecsnsecsssccssscessecenscessccesnecesneessneessnseeseeees 220 
SET TIMESTAMP COMMANG ....e.sssssssssssessssssssssessssecsscssscssscsssecsncsssesssesssccssssnsessscssscsuscsnsesssssucesecssscsscsssscssccsusessessneessecsnessoes 
SET TIMESTAMP parameter data format ... 
START STOP UNIT COMMANG .....esssssssssscsseecestecssecsssecssscesssccssseecssccessccessecsusccssscesaseesseeesuecessescsasecsseeessceesueessneessnecesneeessees 
POWER CONDITION field and POWER CONDITION MODIFIER field .........esssssscsssecsssccssccssescescecssccrssccesseesnecssees 223 
STREAM CONTROL COMMANGA .uecscsssesssssssessscsssesssssssecsnecsuessnecsssssnecsuccesccssecssecsuesssessucsssccsnscsuccsnscssccssscsscssusessessnecssessssesees 
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SYNCHRONIZE CACHE (16) command ... 
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Preferred TEST UNIT READY response .......sssscsssscsssscsssecssscesssccssccsssccesscesssccessecsusecsusecsnscessscesscessscessscessuecesneessseeessecstaes 
UNMAP COMMANG .u...csssssssssssessssssnesssessnssssessnecssecsnscssssnecsssssnscssscsnscsuscsuscsssssnscsssssnscsssssuscsuscesscsuscescsusceseesueseseecascessesnseeseesss 
UNMAP parameter list .ccicsscsiiscvéscavetesevessssonsectdetscayestssicestlaysavessvssevavelsavecutsovsacuavestuancouusesstceuvecheavdvassusdbstsavesacayledeendeussirsst 
UNMAP block descriptor .... 
VERIFY (WO) GOA AINA asks cccscs cesses cesdsdecsbsedcccicd coded acéatesoussseesocbsasdeeashcestaswdsvaceece’cast¥easeealseossaiseceodsecdesasdéssaseussbiacavokensotesscétnoses 
VRPROTECT field with BYTCHK field set to OOb - MECIUIM .......eeessssecsssecsssecsescesseccssccssscesssccssccesseccesccesuecessceesseessess 236 
VRPROTECT field with BYTCHK field set to 01b of 11D - MECIUM .......eecssescssecssccnseecnscesssccsssccsesecsseecssecesseessees 238 
VRPROTECT field with BYTCHK field set to one 01b or 11b - data-OUt DUPPEF on. eesssscssesccssecsseecsseeesseessees 240 
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VRPROTECT field with BYTCHK field set to 01b or 11b - byte-by-byte comparison requirements ........ 242 
ERIE VY. (2) Cor ANG ses 25 sched Sass scas A ct8 vas coax sducSusacdeacecaabactessesassseu adesssecteses css stat badsuese’savectesavotestveseseasedeitvessorsvsdestases 

VERIFY (16) command .. ‘és 
WERIY- (3 2) CO iain sisceics ch cdccesacssashedcsaceulklache5sdeseodseveaseactedcsccdgdsasavsesasda:sosvedssesonsauseuaesbedsvasveduesbedusesqusvossauasbssue todasatestuaivs 
WRITE: (6) CONV AIA GN sess cacsssecascsisdsceics cossasccotesesscssccaxssdecssesuccadcxavsstesedeacesetchcocleausasavecsbsesersecsnssadsesdbduccxesduscsdooudeie\eeseCodscsetese® 
WRITE (10) commana ... ie 
WRPROTEGCT IGN cevscesssscztecoresssevacenstsstdi esse ascesstcsvasststsscianesddes¥sssactasedstecoccessetsenesidews diiets watd wicosata sldsned eeeescastescdesvceeastaseestiens 
WRITE: C12): COMI AT Gh aieccccse caacucctccsse desascvsccveclucsecdacebesbisavctescuccsacsestiieast sarsdkecn deaanstcdas desi ansatsnsens ensreseiich aiseeanretataeaieee ed 
WRITE (16) commana ... = 
WRITE. (32): COMMA G secs cssssssccsssceccssscessevecssasessrsocsactvezecseencesese} sav vinetodsusevenoncossascee¥araseuvaselseovesssass gs sbueteussecsstonsuusitesotoiecseisssé 
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WRITE: BUFFER COMMA ssssssssscassisscosssssecesssesssossecasvessecsecoosssasseusedosesndassecedsetos shosss da cbse cosudsbersseléseessdvovsessetesedssscosecés seosdioys 
WRITE BUFFER MODE field .. - 
MODE SPECIFIC field csi: csszcsissosicsvscessvtetesceitasosagasssosedssecsostsdeesens astsuids ecadeas eessoat scbvevssdspecatetesshaselasebaiutOvesaaesesdess vesseatslessiens 

Application log data WRITE BUFFER format .........ssscssssssssscsssscsssesssccsssscessecsssecsssecsnscesuecesucenscessscessceessscceasecsnseesnseests 270 
ERROR TYPE field ois 
CODE SET FONG sss ccsiis Sessa castesssssacsdsstuscistunssssseesastcnsisGencsaudsvseoviesdecasstavadesdvoavebsutastbussSustiusisbixosssbuesbanes incdessvdvoscésaicoesTeavéestians 

ERROR LOCATION FORMAT field ......cssssssssssssscsscssssssucssssssncsssecsucsssscsscssscesscsassesscsssessucsassesscsscseseessssesscsssseseecsscessessscessesss 272 
WRITE LONG (10) commana ... 7 
WRITE LONG (16) COMMANG ...........sssscssssssssssscsossessssseesesessevsssrocsussssssesssossevssssvssesessevaversessssssssesusossosanssvssseseresesseoesesssesesee 
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WRITE SAME (32) COMMANA aiccccscccccsscsssssssscsscsssscssssscsscssssssscssesssssessesssssssessssscsecsesssssssscsscsesssssssessessessessssesssssssessesssssssees 
WRITE STREAM (16) command 
WRITE STREAM (32) command 
Commands for host Managed ZONE DOCK AeVICES ........ssssscssessccsseecesseserssscecesssccessscersnseecesseecesssecsnsscersnseeseuseeesene 
CLOSE ZONE command .... e 
FINISH ZONE COMMAMNGA ivssicssssssccesscecssssscedssocssueessesssucécsscssesesecousanssstevecssseucscvsssiesossssvinosésvsstbevban susshatatbuséavssoess¥ivsbsbenséeveees 
OPEN ZONE COMMANGA ......csssssssssssssssecssssssscssssssecsssscsnccsssssnecassesscsuscessccasssssccssessscsascesscsssessucssscessessssessecsscessessscsssesaseesneesees 
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REPORT ZONE COMIMAIG sasesscsvsivessiesscecsestenvicoustdoaSeaiGavstivaclsstecsvctcsdetleceosdcaossteabeschshtabicheaseca¥ustd cusbavaitasyssovetéesecbedtanacahtan 286 
REPORT ZONES REPORTING OPTIONS field ........sessssscssssssssccssseccssccsssccessccsseecsnscessseessccesscsssseeseessuccessecssneeeasecssseestaes 287 
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SAME field GeSCriIPtiOn .......sescssssccssscssssecsccsssecsseccsssecsnsccssscesseccssccessccessccsssscesscesssecsssecsscessecessccssscessccesscecsuecesneessneessnseesseees 


ZONE GESCHIPtOK FOLIA, ceseseccessistcassensdhtssceonseckacscussatesccaccacsuilasbsiascenbenconssacsadeancanbsaceeSecce bisa deatsssdsbinchasdencastcaddeabsacedbsecaabeted 
Zone descriptor ZONE TYPE field 
Zone descriptor ZONE CONDITION field 
RESET WRITE POINTER COMIMANG ........ssssscsssssessssssessnseecssssecesssecessssecssutecssnssessnssceesussessnsseessuseessusecsssssessnsssessessessenneessusees 
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Did QmOStic Page COGES. ssccsscssescsisccecvascecesvacseaacdessieceensucncsdcegesisecstiveseesisenssascstsdsscesducesedgeceesaseenslucdeadacdengecnedtapenedueqnebiees dives 
SUPPOrtEd AiAGNOStIC PAGES .....escssssccsssccsscccseecsseecsssccsssccsscessecessccesscessuscssuecesuccessecsnsesssscesseccsusccssceesscessucssueessneessneeessees 
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Rebuild Assist Input diaGnOstic PaGe oe .ssscsssssssessesessseessnseecesssecssuseessnssessnssecssuseessssseessscessuseessessesssnsescesessenneessnsees 
Rebuild Assist Output diagnostic page i 
OG PAGS: COM SS i sestssdece cade tesvcts ceskésGvsncten uct accectsadessscvect svabiesaguctevaddeeadectesvasee adeeb vscnsd vested uuagntesavesh aderdvacstisvaiorssecbeestaiéetvaad 
LOG PAGES FOAL. cesesveccesiscecvsscscassceesavcsacdvscecsiesesndstcenlececsiesecedegeeoiageeedegucadayersdessedevisigagecsivegeulsacesdiasessseqneabapgundsegneanecneaiees 
LOG SELECT PCR bit, SP bit, and DS bit meanings when parameter list length is not zero .. 
LOO PAVAMALE|L sicicisissccscicescstiasssedescevsdasdarisezsudeuscosasdéeedsudesbiesiasdosssedenseobiassoedsadesbiasiatésedsuttnsiebiieseodsadéubie ieebesseadesieedeassesiuissines 
FORMAT AND LINKING fiGIGl ac.scscsssscaccsssessesessssvesossuscacssvevsesuseccuvecsesvecdeeuscsorsvecsesvesooruvecsesvesssevecoseusendsevesdssusesdesvedsseusstsrnie 
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Parameter control byte values for binary format list log parameters ... 
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Application Client log page parameter COGES ..sesccssssssssssssssssseesseccssscsssecssecssssecssscessecsssecssseerssccesecesseeceseeesnecssseests 
Application Client 10g Page ....ssesssssscssecsseccsseessteeesseessees 
General usage application client parameter data 
Background Scan log page parameter COCES on... essssesscsssescessseesssseessnseecessnecssnsecsssseessunecssuseeesussesensnsesenssesensneeesneees 
Background Scan 10g Page «ne .sssessccsessceseeeesnseecesneeees 

Background Scan Status parameter format 
Background Scan Status fiCId oc essssssssessssessssssessnseessssscesssecsssssesssssesesussessssesssssesesuseessussesssseesssunsessesesssuneessessessensess 
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A; Definitions, Symbols, Abbreviations, Keywords, And Conventions 


This clause contains the definitions, symbols, abbreviations, keywords and, conventions used throughout this manual. These 
items are from the American National Standards Institute T10 committee standards. 


Applicable Documents: 

INCITS 515 SCSI Architecture Model - 5 (SAM-5) Revision 11 
INCITS 502 SCSI Primary Commands - 5 (SPC-5) Revision 10 
INCITS 506 SCSI Block Commands - 4 (SBC-4) Revision 10 
INCITS 536 Zoned Block Commands (ZBC) 

INCITS 534 Serial Attached SCSI - 4 (SAS-4) 

INCITS 538 SAS Protocol Layer - 4 (SPL-4) Revision 08 


ANSI INCITS 481-2011 Fibre Channel Protocol for SCSI, - 4 (FCP-4) 
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1.1 Definitions 


Access control list (ACL) 

The data used by a SCSI target device to configure access rights for initiator ports according to the access controls state of the SCSI target 
device. 

Access control list entry (ACE) 

One entry in the access control list. 

Access controls 

An optional SCSI target device feature that restricts initiator port access to specific logical units and modifies the information about logical 
units in the parameter data of the INQUIRY and REPORT LUNS commands. 

Access controls coordinator 

The entity within a SCSI target device that coordinates the management and enforcement of access controls for all logical units within the SCSI 
target device. The access controls coordinator is always addressable through the ACCESS CONTROLS well known logical unit and LUN 0. 
active power condition 

When a device server is capable of responding to all of its supported commands, including media access requests, without delay. 

additional sense code 

A combination of the ADDITIONAL SENSE CODE and ADDITIONAL SENSE CODE QUALIFIER fields in the sense data. 

Application client 

An object that is the source of SCSI commands. Further definition of an application client may be found in SAM-5. 

Attribute 

A single unit of MAM information. 

Auto contingent allegiance (ACA) 

The task set condition established following the return of a CHECK CONDITION status when the NACA bit is set to one in the CONTROL byte. A 
detailed definition of ACA may be found in Clause 2.2.7. 

Blocked task 

A task that is in the blocked state. Tasks become blocked when an ACA condition occurs. The blocked state ends when the ACA condition is 
cleared. A detailed definition of the blocked task state may be found in SAM-5. 

Byte 

A sequence of eight contiguous bits considered as a unit. 

Cache 

See cache memory. 

Cache memory 

A temporary and often volatile data storage area outside the area accessible by application clients that may contain a subset of the data stored 
in the non-volatile data storage area. 

Check data 

Information contained within a redundancy group that may allow lost or destroyed XOR-protected data to be recreated. 

Command 

A request describing a unit of work to be performed by a device server. A detailed definition of a command may be found in SAM-5. 
Command descriptor block (CDB) 

The structure used to communicate commands from an application client to a device server. A CDB may have a fixed length of up to 16 bytes or 
a variable length of between 12 and 260 bytes. 

Command standard 

A SCSI standard that defines the model, commands, and parameter data for a device type (e.g., SBC-4, SSC-3, SMC-3, MMC-5, or SES-3). 
Company_id 

Synonym for OUI. 

Copy manager 

The device server that receives an EXTENDED COPY command and performs the operation requested. 
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Copy target device 

The name given by the EXTENDED COPY command to a source or destination logical unit (i.e., a copy target device is a logical unit, not a SCSI 
target device). 

Cyclic redundancy check (CRC) 

An error checking mechanism that checks data integrity by computing a polynomial algorithm based checksum. 


Data defect list (DLIST) 
A list of defects sent by the application client to the device server during a FORMAT UNIT command. 


Data-in buffer 
The buffer specified by the application client to receive data from the device server during the processing of a command. 


Data-out buffer 


The buffer specified by the application client to supply data that is sent from the application client to the device server during the processing of 
a command. 


Default protection information 
Values placed into protection information fields if an application client does not specify specific protection information values: 


Deferred error 

A CHECK CONDITION status and sense data that is returned as the result of an error or exception condition that occurred during processing of 
a previous command for which GOOD, CONDITION MET, INTERMEDIATE, and INTERMEDIATE-CONDITION MET status has already been returned. 
Device server 

An object within a logical unit that processes SCSI tasks according to the rules of task management. A detailed definition of a device server may 
be found in SAM-5. 

Device service request 

A request, submitted by an application client, conveying a SCSI command to a device server. A detailed definition of a device service request 
may be found in SAM-5. 

Device service response 

The response returned to an application client by a device server on completion of a SCSI command. A detailed definition of a device service 
response may be found in SAM-5. 

Device type 

The type of peripheral device (i.e., device model) implemented by the device server and indicated by the contents of the PERIPHERAL DEVICE 
TYPE field in the standard INQUIRY data. 

Direct-access block device 

A device that is capable of containing data stored in blocks that each have a unique logical block address. 

Domain 

An I/O system consisting of a set of SCSI devices that interact with one another by means of a service delivery subsystem. 

Element 

An addressable physical component of a medium changer SCSI device that may serve as the location of a removable unit of data storage 
medium. A detailed definition of an element may be found in SMC-3. 

Enabled task state 

The only task state in which a task may make progress towards completion. A detailed definition of the enabled task state may be found in 
SAM-5. 


Error correcting code (ECC) 
An error checking mechanism that checks data integrity and enables some errors in the data to be corrected. 


Error history I_T nexus 
An |_T nexus for which the device server has reserved access to the error history snapshot (see SPC-5). 


Error history snapshot 
The contents of the error history at a specific point in time (see SPC-5). 


Exclusive-or (XOR) 
A Boolean arithmetic function on two binary input values that results in an output value of 1 if one and only one of the input values is 1. 
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Extended Unique Identifier, a 48-bit globally unique identifier (EUI-48) 
The IEEE maintains a tutorial describing EUI-48 at http://standards.ieee.org/regauth/oui/tutorials/EUI48.html. 


Extended Unique Identifier, a 64-bit globally unique identifier (EUI-64) 
The IEEE maintains a tutorial describing EUI-64 at http://standards.ieee.org/regauth/oui/tutorials/EUI64.html. 








Extent 
A fixed set of logical blocks occupying contiguous logical block addresses on a single logical unit. 


Faulted I_T nexus 
The |_T nexus on which a CHECK CONDITION status was returned that resulted in the establishment of an ACA. The faulted I_T nexus condition 
is cleared when the ACA condition is cleared. 


Field 
A group of one or more contiguous bits, a part of a larger structure such as a CDB or sense data. 


Format corrupt 
a vendor-specific condition in which the application client may not be able to perform read operations, write operations, or verify operations. 


Grown defect list (GLIST) 
All defects sent by the application client to the device server. 


Hard reset 

A condition resulting from the events defined by SAM-5 in which the SCSI device performs the hard reset operations described in SAM-5, 
SPC-5, and the applicable command standards. 

Host 


A SCSI device with the characteristics of a primary computing device, typically a personal computer, workstation, server, minicomputer, main- 
frame computer, or auxiliary computing device. A host includes one or more SCSI initiator devices. 


IEEE company_id 
Synonym for OUI. 


LT nexus 
A nexus between a SCSI initiator port and a SCSI target port. 


|_T nexus loss 
A condition resulting from the events defined by SAM-5 in which the SCSI device performs the I_T nexus loss operations described in SAM-5, 
SPC-5, and the applicable command standards. 


L_T_Lnexus 
A nexus between a SCSI initiator port, a SCSI target port, and a logical unit. 


|_T_L_Qnexus transaction 
The information transferred between SCSI ports in a single data structure with defined boundaries (e.g., an information unit). 


Idle power condition 
When a device server is capable of responding to all of its supported commands, including media access requests, but commands may take 
longer to complete than when in the active power condition. 


Implicit head of queue 
An optional processing model for specified commands wherein the specified commands may be treated as if they had been received with a 
HEAD OF QUEUE task attribute. 


Initiator device name 

A SCSI device name of a SCSI initiator device or of a SCSI target/initiator device when operating as a SCSI initiator device. 
Initiator port 

Synonymous with SCSI initiator port. 

Initiator port identifier 

A value by which a SCSI initiator port is referenced within a SCSI domain. 

Initiator port name 

A SCSI port name of a SCSI initiator port or of a SCSI target/initiator port when operating as a SCSI initiator port. 


Internet protocol domain name 
The name of a computer or hierarchy of computers within the domain name system defined by the IETF (see RFC 1035 and RFC 1591). The 
Internet Assigned Numbers Authority maintains a list of domain name assignments at http://www.iana.org/assignments/domain-names. 
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Internet protocol number 

A coded value assigned to identify protocols that layer on the Internet protocol (see RFC 791). The Internet protocol number assigned to the 
transmission control protocol (TCP, see RFC 793) is six. The Internet Assigned Numbers Authority maintains a list of Internet protocol number 
assignments at http://www.iana.org/assignments/protocol-numbers. 

Least significant bit (LSB) 

In a binary code, the bit or bit position with the smallest numerical weighting in a group of bits that, when taken as a whole, represent a numer- 
ical value (e.g., in the number 0001b, the bit that is set to one). 

Left-aligned 

A type of field containing ASCII data in which unused bytes are placed at the end of the field (highest offset) and are filled with ASCII space 
(20h) characters. 

Logical block 

A set of data bytes accessed and referenced as a unit. 


Logical block address (LBA) 

The value used to reference a logical block. 

Logical unit 

An externally addressable entity within a SCSI target device that implements a SCSI device model and contains a device server. A detailed defi- 
nition of a logical unit may be found in SAM-5. 

Logical unit access control descriptor (LUACD) 

The structure within an ACE that identifies a logical unit to which access is allowed and specifies the LUN by which the logical unit is to be 
accessed. 

Logical unit certification list (CLIST) 

Defects detected by the device server during an optional certification process performed during the FORMAT UNIT command. 

Logical unit inventory 

The list of the logical unit numbers reported by a REPORT LUNS command. 

Logical unit number (LUN) 

An encoded 64-bit identifier for a logical unit. A detailed definition of a logical unit number may be found in SAM-5. 

Logical unit reset 

A condition resulting from the events defined by SAM-5 in which the logical unit performs the logical unit reset operations described in SAM-5, 
SPC-5, and the applicable command standards. 

Media 

Plural of Medium 

Medium 

A physical entity that stores data in a nonvolatile manner (i.e., retained through a power cycle) in accordance with commands processed by the 
device server. 

Medium auxiliary memory (MAM) 

An auxiliary memory residing on a medium that is accessible to the device server (e.g., a tape cartridge). Medium auxiliary memory may be 
nonvolatile and independent of the main function of the device server. 

Most significant bit (MSB) 

In a binary code, the bit or bit position with the largest numerical weighting in a group of bits that, when taken as a whole, represent a numer- 
ical value (e.g., in the number 1000b, the bit that is set to one). 

Name 

A label of an object that is unique within a specified context and should never change (e.g., the term name and worldwide identifier (WWID) 
may be interchangeable). 

Network address authority (NAA) 

A field within a name that specifies the format and length of that name. See FC-FS. 

Nexus 

A relationship between two SCSI devices, and the SCSI initiator port and SCSI target port objects within those SCSI devices. 

Non-volatile cache 

Cache that retains data through power cycles. 


Non-volatile cache memory 
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Cache memory that retains data through power cycles. 


Non-volatile medium 

A physical storage medium that retains data written to it for subsequent read operations through power cycles (e.g., a disk within a device that 
stores data as magnetic field changes that do not require device power to exist). 

Null-padded 

A type of field in which unused bytes are placed at the end of the field (i.e., highest offset) and are filled with ASCII null (00h) characters. 


Null-terminated 
A type of field in which the last used byte (i.e., highest offset) is required to contain an ASCII null (00h) character. 


One 
The logical true condition of a variable. 


Operation Code 
The first byte of a SCSI CDB shall contain an operation code identifying the operation being requested by the CDB. 


Organizationally unique identifier (OUI) 

A numeric identifier that is assigned by the IEEE such that no assigned identifiers are identical. OUI is equivalent to company_id or IEEE compa- 
ny_id. The IEEE prefers OUI for EUI-48 identifiers and company_id for EUI-64 identifiers. However, the numeric identifier is called an OUI when it 
is assigned by the IEEE. The IEEE maintains a tutorial describing the OUI at http://standards.ieee.org/regauth/oui/. 





Page 

A regular parameter structure (or format) used by several commands. These pages are identified with a value known as a page code. 
Persist through power loss 

An optional capability associated with some features that allows an application client to request that a device server maintain information 
regarding that feature across power failures. 

Persistent reservation holder 

The I_T nexus(es) that are allowed to release or change a persistent reservation without preempting it. 

Power cycle 

Power being removed from and later applied to a SCSI device. 

Power on 

A condition resulting from the events defined by SAM-5 in which the SCSI device performs the power on operations described in SAM-5, SPC-5, 
and the applicable command standards. 

Primary defect list (PLIST) 

The list of defects that are considered permanent defects. 

Protection information 

Fields appended to each logical block that contain a cyclic redundancy check (CRC), an application tag, and a reference tag. 

Protocol identifier 

A coded value used in various fields to identify the protocol to which other fields apply. 

Protocol specific 

A requirement that is defined by a SCSI transport protocol standard. A detailed definition of protocol specific may be found in SAM-5. 
Protocol standard 

A SCSI standard that defines SCSI transport protocol (e.g., SAS, SBP-3, or FCP-2). 

Proxy token 

An identifier for a logical unit that may be used to gain temporary access to that logical unit in the presence of access controls. 
Redundancy group 


A grouping of XOR-protected data and associated check data into a single type of data redundancy (see SCC-2). SPC-5 only supports the XOR 
type of redundancy. 


Request for comment (RFC) 
The name given to standards developed by the Internet Engineering Task Force. 
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Registered 

The condition that exists for an |_T nexus following the successful completion of a PERSISTENT RESERVE OUT command with a REGISTER ser- 
vice action, REGISTER AND IGNORE EXISTING KEY service action, or REGISTER AND MOVE service action and lasting until the registration is 
removed. 


Registrant 

An |_T nexus that is registered. 

Right-aligned 

A type of field containing ASCII data in which unused bytes are placed at the start of the field (i.e., lowest offset) and are filled with ASCII space 
(20h) characters. 


Relative port identifier 
An identifier for a SCSI port that is unique within a SCSI device. Application clients may use the SCSI Ports VPD page to determine relative port 
identifier values. 


Relative initiator port identifier 
A relative port identifier for a SCSI initiator port. 


Relative target port identifier 
A relative port identifier for a SCSI target port. 


SCSI device 
A device that contains one or more SCSI ports that are connected to a service delivery subsystem and supports a SCSI application protocol. 


SCSI device name 
A name of a SCSI device that is world wide unique within the protocol of a SCSI domain in which the SCSI device has SCSI ports. The SCSI device 
name may be made available to other SCSI devices or SCSI ports in protocol specific ways. 


SCSI domain 

The interconnection of two or more SCSI devices and a service delivery subsystem. A detailed definition of a SCSI Domain may be found in 
SAM-5. 

SCSI initiator device 

A SCSI device containing application clients and SCSI initiator ports that originate device service and task management requests to be pro- 
cessed by a SCSI target device and receives device service and task management responses from SCSI target devices. 


SCSI initiator port 

A SCSI initiator device object acts as the connection between application clients and the service delivery subsystem through which requests 
and responses are routed. 

SCSI port 

A port of a SCSI device that connects the application client, device server or task manager to the service delivery subsystem. 


SCSI port identifier 
A value by which a SCSI port is referenced within a domain. The SCSI port identifier is either an initiator port identifier or a target port identifier. 


SCSI port name 
A name of a SCSI port that is world wide unique within the protocol of the SCSI domain of that SCSI port. The name may be made available to 
other SCSI devices or SCSI ports in that SCSI domain in protocol specific ways. 


SCSI Ports VPD page 
AVPD page that allows retrieval of information about all the SCSI ports in a SCSI target device or SCSI target/initiator device. 


SCSI target device 
A SCSI device containing logical units and SCSI target ports that receives device service and task management requests for processing and 
sends device service and task management responses to SCSI initiator devices. 


SCSI target port 
A SCSI target device object that acts as the connection between device servers and task managers and the service delivery subsystem through 
which requests and responses are routed. 


SCSI transport protocol standard 
A SCSI standard that defines a SCSI transport protocol (e.g., FCP-2, SAS, SRP, or SBP-3). 
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Sense data 
Data describing an error or exceptional condition that a device server delivers to an application client in the same |_T_L_Q nexus transaction as 
a CHECK CONDITION status or in response to a REQUEST SENSE command. The format of sense data is defined in SPC-5. 


Sense key 
The contents of the SENSE KEY field in the sense data. 


Service action 
A request describing a unit of work to be performed by a device server. A service action is an extension of a command. 


Service delivery subsystem 
That part of a SCSI I/O system that transmits service requests to a logical unit or SCSI target device and returns logical unit or SCSI target device 
responses to a SCSI initiator device. 


Standby power condition 
When a device server is capable of accepting commands, but not capable of processing media access commands. 


Status 
One byte of response information sent from a device server to an application client upon completion of each command. 


Storage array controller 

Any combination of an initiator and application clients (see SAM-5) that originates SCSI commands, converts input LUNs to output LUNs, and 
converts input LBAs to output LBAs. A storage array controller organizes a group of direct-access block devices into various objects (e.g., redun- 
dancy groups and volume sets). See SCC-2. 


System 
One or more SCSI domains operating as a single configuration. 


Target device name 
A SCSI device name of a SCSI target device or of a SCSI target/initiator device when operating as a SCSI target device. 


Target port 
Synonymous with SCSI target port. 


Target port asymmetric access state 
The characteristic that defines the behavior of a target port and the allowable command set for a logical unit when commands and task man- 
agement functions are routed through the target port maintaining that state. 


Target port group 
A set of target ports that are in the same target port asymmetric access state at all times. 


Target port group asymmetric access state 
The target port asymmetric access state common to the set of target ports in a target port group. 


Target port identifier 
A value by which a SCSI target port is referenced within a SCSI domain. 


Target port name 
A SCSI port name of a SCSI target port or of a SCSI target/initiator port when operating as a SCSI target port. 


Task 
An object within a logical unit that represents the work associated with a command or a group of linked commands. A detailed definition of a 
task may be found in SAM-5. 


Task set 
A group of tasks within a logical unit, whose interaction is dependent on the task management (queuing) and ACA rules. See SAM-5 and the 
Control mode page. 


TCP port numbers 

One of the data needed to establish a TCP connection. TCP port numbers may be assigned to protocols that layer on TCP by the Internet 
Assigned Numbers Authority. The Internet Assigned Numbers Authority maintains a list of TCP port number assignments at 
http://www.iana.org/assignments/ port-numbers. 





Third-party command 

A command sent to one SCSI device requesting than an operation be performed involving two other SCSI devices (e.g., the EXTENDED COPY 
command may perform copy operations between two or more SCSI devices none of which are the SCSI device to which the EXTENDED COPY 
command was sent). 
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Unit attention condition 

A state that a logical unit maintains while it has asynchronous status information to report to the initiator ports associated with one or more |_T 
nexuses. See SAM-5. 

Universal time (UT) 

The time at longitude zero, colloquially known as Greenwich Mean Time. See http://aa.usno.navy.mil/faq/docs/UT.html. 

URI Schemes 

The Internet Assigned Numbers Authority maintains a list of schemes for URI and URL names at http://www.iana.org/assignments/uri-schemes. 





User data 

Data contained in logical blocks that is not protection information. 

UTF-8 

A character set that is a transformation format of the character set defined by ISO 10646. See RFC 2279. 


Vendor specific (VS) 
Something (e.g., a bit, field, or code value) that is not defined by SPC-5 and may be vendor defined. 


Volatile cache memory or Volatile cache 
Cache memory that does not retain data through power cycles. 


Volatile medium 
Medium that does not retain data written to it for a subsequent read operation through power cycles (e.g., a silicon memory device that loses 
data written to it if device power is lost). 


Well known logical unit 

A logical unit that only does specific functions. Well known logical units allow an application client to issue requests to receive and manage 
specific information usually relating to a SCSI target device. 

Well known logical unit number (W-LUN) 

The logical unit number that identifies a well known logical unit. 


XOR operation 

Performing an XOR bitwise on two identical-sized multiple-bit input values (e.g., the current value of a logical block and the new value for that 
logical block). In a storage array implementing a redundancy group, the XOR operation is used in error correction algorithms and may be per- 
formed by the storage array controller or by the direct-access block devices. 

XOR-protected data 

Logical blocks, including user data and protection information, if any, that are part of a redundancy group. 


Zero 
The logical false condition of a variable. 


Zero-padded 
A type of field in which unused bytes are placed at the end of the field (i.e., highest offset) and are filled with zeros. 
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See Table 1 for abbreviations of standards bodies (e.g., ISO). Additional symbols and abbreviations used in the manual include: 


Abbreviation Meaning 


< less than 

> greater than 

ACE Access Control list Entry 

ACL Access Control List 

ACA Auto Contingent Allegiance 

ASC Additional Sense Code 

ASCII American Standard Code for Information Interchange 
ASCQ Additional Sense Code Qualifier 

ATA AT Attachment (see www.t13.org) 

CDB Command Descriptor Block 

CRC Cyclic Redundancy Check 

CLIST logical unit certification list 

D_ID Destination Identifier (defined in FC-FS) 
DLIST data defect list 

ECC error correcting code 

EUI-48 Extended Unique Identifier, a 48-bit globally unique identifier 
EUI-64 Extended Unique Identifier, a 64-bit globally unique identifier 
FC Fibre Channel 

FC-FS Fibre Channel Framing and Signaling Interface 
FCP-4 Fibre Channel Protocol for SCSI -4 

GLIST grown defect list 

HTTP Hypertext Transfer Protocol (see RFC 2616) 

1/0 input/output 

ID Identifier or Identification 

IEC International Electrotechnical Commission 
IEEE Institute of Electrical and Electronics Engineers 
IETF Internet Engineering Task Force 

IP Internet Protocol 

IPv4 Internet Protocol version 4 

IPv6é Internet Protocol version 6 

iSCSI Internet SCSI 

Iso Organization for International Standards 

LBA Logical Block Address 

LSB Least Significant Bit 

LUACD Logical Unit Access Control Descriptor 

LUN Logical Unit Number 

MAM Medium Auxiliary Memory 

MMC-5 SCSI Multi-Media Commands -5 

MSB Most Significant Bit 

NAA Network Address Authority 

n/a not applicable 

INCITS InterNational Committee for Information Technology Standards 
OSD Object-based Storage Devices Commands 

OUI Organizationally Unique Identifier 

PLIST primary defect list 

RAID Redundant Array of Independent Disks 

RBC SCSI Reduced Block Commands 

RDMA Remote Direct Memory Access (see SRP) 

RFC Request For Comments 
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RMC SCSI Reduced Multi-Media Commands 

SAM-5 SCSI Architecture Model -5 

SAS Serial Attached SCSI 

SAT SCSI / ATA Translation 

SBC-4 SCSI Block Commands -4 

SCSI The architecture defined by the family of standards described in clause 1 
SES-3 SCSI Enclosure Services -3 

SPC-5 SCSI Primary Commands -5 

SRP SCSI RDMA Protocol 

SSC-2 SCSI Stream Commands -2 

SSP Serial SCSI Protocol 

TCP Transmission Control Protocol (see RFC 793) 

URI Uniform Resource Identifier (see RFC 2396 and RFC 3305) 
URL Uniform Resource Locator (see RFC 2396 and RFC 3305) 
UT Universal time 

USB Universal Serial Bus (see www.usb.org) 

VPD Vital Product Data 

VS Vendor Specific 

W-LUN Well known logical unit number 
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1.3 Keywords 


Expected 
A keyword used to describe the behavior of the hardware or software in the design models assumed by this manual. Other hardware and soft- 
ware design models may also be implemented. 


Ignored 
A keyword used to describe an unused bit, byte, word, field or code value. The contents or value of an ignored bit, byte, word, field or code 
value shall not be examined by the receiving SCSI device and may be set to any value by the transmitting SCSI device. 


Invalid 
A keyword used to describe an illegal or unsupported bit, byte, word, field or code value. Receipt of an invalid bit, byte, word, field or code 
value shall be reported as an error. 


Mandatory 

A keyword indicating an item that is required to be implemented as defined in this manual. 

May 

A keyword that indicates flexibility of choice with no implied preference (equivalent to “may or may not”). 

May not 

Keywords that indicate flexibility of choice with no implied preference (equivalent to “may or may not”). 

Obsolete 

A keyword indicating that an item was defined in prior SCSI standards but has been removed from this manual. 

Optional 

A keyword that describes features that are not required to be implemented by the standard. However, if any optional feature defined in the 
standard is implemented, then it shall be implemented as defined in this manual. 

Reserved 

A keyword referring to bits, bytes, words, fields and code values that are set aside for future standardization. A reserved bit, byte, word or field 
shall be set to zero, or in accordance with a future extension to this manual. Recipients are not required to check reserved bits, bytes, words or 
fields for zero values. Receipt of reserved code values in defined fields shall be reported as an error. 

Restricted 

A keyword referring to bits, bytes, words, and fields that are set aside for use in other SCSI standards. A restricted bit, byte, word, or field shall be 
treated as a reserved bit, byte, word or field for the purposes of the requirements defined in this manual. 

Shall 

A keyword indicating a mandatory requirement. Designers are required to implement all such mandatory requirements to ensure interopera- 
bility with other products that conform to this manual. 

Should 

A keyword indicating flexibility of choice with a strongly preferred alternative; equivalent to the phrase “it is strongly recommended.’ 
Vendor-specific 

Something (e.g., a bit, field, or code value) that is not defined by this manual and may be used differently in various implementations. 
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1.4 Conventions 


Certain words and terms used in this manual have a specific meaning beyond the normal English meaning. These words and 
terms are defined either in this clause or in the text where they first appear. Names of commands, status codes, sense keys, and 
additional sense codes are in all uppercase (e.g., REQUEST SENSE). 


If there is more than one CDB length for a particular command (e.g., MODE SENSE(6) and MODE SENSE(10) and the name of the 
command is used in a sentence without any CDB length descriptor (e.g., MODE SENSE), then the condition specified in the 
sentence applies to all CDB lengths for that command. 


Names of fields and state variables are in uppercase (e.g. NAME). When a field or state variable name contains acronyms, 
uppercase letters may be used for readability. Normal case is used when the contents of a field or state variable are being 
discussed. Fields or state variables containing only one bit are usually referred to as the NAME bit instead of the NAME field. 


Normal case is used for words having the normal English meaning. 


A binary number is represented in this manual by any sequence of digits comprised of only the Western-Arabic numerals 0 and 1 
immediately followed by a lower-case b (e.g., 0101b). Underscores or spaces may be included between characters in binary 
number representations to increase readability or delineate field boundaries (e.g.,0 0101 1010b or 0_0101_1010b). 


A hexadecimal number is represented in this manual by any sequence of digits comprised of only the Western-Arabic numerals 
0 through 9 and/or the upper-case English letters A through F immediately followed by a lower-case h (e.g., FA23h). Underscores 
or spaces may be included in hexadecimal number representations to increase readability or delineate field boundaries (e.g., B 
FD8CFA23h or B_FD8C_FA23h). 


A decimal number is represented in this manual by any sequence of digits comprised of only the Western-Arabic numerals 0 
through 9 not immediately followed by a lower-case b or lower-case h (e.g., 25). 


When the value of the bit or field is not relevant, x or xx appears in place of a specific value. 


This manual uses the ISO convention for representing decimal numbers (e.g., the thousands and higher multiples are separated 
by a space and a commais used as the decimal point). Table 1 shows some examples of decimal numbers represented using the 
ISO and American conventions. 











Table 1 ISO v American Numbering Conventions 
Iso American 
0,6 0.6 
| 314159265 | 314159265 | 
1 000 1,000 
| 1323462] ~—«*1,323,462.95 | 














Lists sequenced by letters (e.g., a) red, b) blue, c) green) show no ordering relationship between the listed items. Lists sequenced 
by numbers (e.g., 1) red, 2) blue, 3) green) show an ordering relationship between the listed items. 


If a conflict arises between text, tables or figures, the order of precedence to resolve the conflicts is text, then tables, and finally 
figures. Not all tables or figures are fully described in the text. Tables show data format and values. Notes do not constitute any 
requirements for implementors. 
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2; General Concepts 


This manual defines behaviors that are common to all Seagate SCSI device models. This manual defines the SCSI commands that 
are basic to more than one disk drive model and the SCSI commands that may apply to any SCSI Interface, including Fibre 
Channel and Serial Attached SCSI (SAS). 


2.1 Command Descriptor Block (CDB) 


2.1.1 CDB usage and structure 


A command is communicated by sending a command descriptor block (CDB) to the device server. For several commands, the 
CDB is accompanied by a list of parameters in the Data-Out Buffer. See the specific commands for detailed information. 


If a logical unit validates reserved CDB fields and receives a reserved field within the CDB that is not zero, then the logical unit 
shall terminate the command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional 
sense code set to INVALID FIELD IN CDB. 


If a logical unit receives a reserved CDB code value in a field other than the OPERATION CODE field, then the logical unit shall 
terminate the command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense 
code set to INVALID FIELD IN CDB. 


The fixed length CDB formats are described in 2.1.2. The variable length CDB formats are described in 2.1.4. The CDB fields that 
are common to most commands are described in 2.1.5. The fields shown in 2.1.2 and 2.1.3 and described in 2.1.4 are used 
consistently by most commands. However, the actual usage of any field (except OPERATION CODE and CONTROL) is described in 
the subclause defining that command. If a device server receives a CDB containing an operation code that is invalid or not 
supported, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and 
the additional sense code set to INVALID COMMAND OPERATION CODE. 


For all commands, if there is an invalid parameter in the CDB, the device server shall terminate the command without altering 
the medium. 
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2.1.2 The fixed length CDB formats 


All fixed length CDBs shall have an OPERATION CODE field as their first byte and a CONTROL byte as their last byte. Table 2 shows 
the typical format of a 6-byte CDB. Table 3 shows the typical format of a 10-byte CDB. Table 4 shows the typical format of a 
12-byte CDB. Table 5 shows the format of a 16-byte CDB for commands that provide for a long LBA. 


Table 2 Typical CDB for 6-byte commands 



































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE 

1 Miscellaneous CDB information (MSB) 

2 





LOGICAL BLOCK ADDRESS (if required) ee 
3 (LSB) 





TRANSFER LENGTH (if required) 
4 PARAMETER LIST LENGTH (if required) 
ALLOCATION LENGTH (if required) 





5 CONTROL 














Table 3 Typical CDB for 10-byte commands 














Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE 

1 Miscellaneous CDB information SERVICE ACTION (if required) 

2 (MSB) 





LOGICAL BLOCK ADDRESS (if required) 














5 (LSB) 
6 Miscellaneous CDB information 
7 (MSB) TRANSFER LENGTH (if required) 

PARAMETER LIST LENGTH (if required) 
8 ALLOCATION LENGTH (if required) (LSB) 
9 CONTROL 
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Table 4 Typical CDB for 12-byte commands 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE 
1 Miscellaneous CDB information SERVICE ACTION (if required) 
2 (MSB) 
LOGICAL BLOCK ADDRESS (if required) 
5 (LSB) 
6 (MSB) 
TRANSFER LENGTH (If required) 
PARAMETER LIST LENGTH (if required) 
ALLOCATION LENGTH (if required) 
9 (LSB) 
10 Miscellaneous CDB information 
11 CONTROL 
Table 5 Typical CDB for long LBA 16-byte commands 
Bit 7 6 5 4 3 2 0 
Byte 
0 OPERATION CODE 
1 Miscellaneous CDB information 
2 (MSB) 
LOGICAL BLOCK ADDRESS 
9 (LSB) 
10 (MSB) 
TRANSFER LENGTH (lf required) 
PARAMETER LIST LENGTH (if required) 
ALLOCATION LENGTH (if required) 
13 (LSB) 
14 Miscellaneous CDB information 
15 CONTROL 
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2.1.3 The variable length CDB formats 


The first byte of a variable length CDB shall contain the operation code 7Fh. The CONTROL byte is the second byte in the variable 
length CDB (see table 6) 


Table 6 Typical variable length CDB 




































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (7Fh) 
1 CONTROL 
2 Miscellaneous CDB information 
3 Miscellaneous CDB information 
4 Miscellaneous CDB information 
5 Miscellaneous CDB information 
6 Miscellaneous CDB information 
7 ADDITIONAL CDB LENGTH (n-7) 
8 (MSB) 
SERVICE ACTION 
9 (LSB) 
10 (MSB) 
Service Action specific fields 
n (LSB) 











ADDITIONAL CDB LENGTH field 


The ADDITIONAL CDB LENGTH field specifies the number of additional CDB bytes. This value in the ADDITIONAL CDB LENGTH field shall be a 
multiple of 4. If the number of CDB bytes delivered by the service delivery subsystem is not sufficient to contain the number of bytes specified 
by the ADDITIONAL CDB LENGTH field, then the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLE- 
GAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


SERVICE ACTION field 


The SERVICE ACTION field specifies the action being requested by the application client. The SERVICE ACTION field is required in the variable 
length CDB format and is described in 4.3.4.2. Each service action code description defines a number of service action specific fields that are 
needed for that service action. 
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A 32-byte variable length CDB format is defined for long LBA operations (see table 7) 


Table 7 Typical variable length CDB for long LBA 32-byte commands 


































































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (7Fh) 
1 CONTROL 
2 Miscellaneous CDB information 
3 Miscellaneous CDB information 
4 Miscellaneous CDB information 
5 Miscellaneous CDB information 
6 Miscellaneous CDB information 
7 Additional CDB Length (n-7) [9] 
8 (MSB) 
5 SERVICE ACTION (LSB) 
10 Miscellaneous CDB information DPO FUA Miscellaneous CDB information 
11 Miscellaneous CDB information 
12 (MSB) 
LOGICAL BLOCK ADDRESS 

19 (LSB) 
20 (MSB) 

Miscellaneous CDB information 
27 (LSB) 
28 (MSB) 

TRANSFER LENGTH (If required) 

PARAMETER LIST LENGTH (if required) 

31 ALLOCATION LENGTH (if required) (LSB) 
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2.2 Common CDB fields 


2.2.1 OPERATION CODE 


The first byte of a SCSI CDB shall contain an operation code identifying the operation being requested by the CDB. Some 
operation codes provide for modification of their operation based on a service action (see 2.2.2). In such cases, the operation 
code and service action code combine to identify the operation being requested. The location of the SERVICE ACTION field in the 
CDB varies depending on the operation code value. 


The OPERATION CODE (see table 9) of the CDB has a GROUP CODE field and aCOMMAND CODE field. The three-bit GROUP CODE 
field provides for eight groups of command codes. The five-bit COMMAND CODE field provides for thirty-two command codes in 
each group. A total of 256 possible operation codes exist. Operation codes are defined in this manual and other command 
standards. The group code value shall determine the length of the CDB (see table 10). 


Table 8 OPERATION CODE byte 





Bit 7 6 5 4 3 2 1 0 























GROUP CODE COMMAND CODE 














The value in the GROUP CODE field specifies one of the groups shown in Table 9. 















































Table 9 Group Code values 
Group Code Meaning Typical CDB Format 
000b 6 byte commands see Table 2 
001b 10 byte commands see Table 3 
010b 10 byte commands see Table 3 
011b Reserved [a] 
100b 16 byte commands see Table 5 and Table 6 
101b 12 byte commands see Table 4 
110b Vendor Specific 
111b Vendor Specific 
[a] The format of the commands using operation code 7Fh is described in 2.1.3. With 
the exception of operation code 7Fh, all group code 011b operation codes are 
reserved. 
2.2.2 SERVICE ACTION 


All CDB formats except the 6-byte format provide for a SERVICE ACTION field containing a coded value identifying a function to 
be performed under the more general command function specified in the OPERATION CODE field. While the SERVICE ACTION 
field is defined for CDB formats, it is used as described in this subclause only in those CDB formats that contain a SERVICE 
ACTION field. When the specific field SERVICE ACTION is not defined in a CDB format, the bits identified as the SERVICE ACTION 
field in a CDB shall be used or reserved as specified by the particular CDB format. 
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2.2.3 LOGICAL BLOCK ADDRESS 


The logical block addresses on a logical unit or within a volume or partition shall begin with block zero and be contiguous up to 
the last logical block of that logical unit or within that volume or partition. 


A six-byte CDB may contain a 21-bit LOGICAL BLOCK ADDRESS field. The ten-byte and the twelve-byte CDBs may contain 32-bit 
LOGICAL BLOCK ADDRESS fields. The sixteen-byte CDB has two formats: one allows a 32-bit LOGICAL BLOCK ADDRESS field (see 
table 5) and the other allows a 64-bit LOGICAL BLOCK ADDRESS field (see table 6). LOGICAL BLOCK ADDRESS fields in additional 
parameter data have their length specified for each occurrence. See the specific command descriptions. 


2.2.4 TRANSFER LENGTH 


The TRANSFER LENGTH field specifies the amount of data to be transferred, usually the number of blocks. Some commands use 
transfer length to specify the requested number of bytes to be sent as defined in the command description. 


Commands that use one byte for the TRANSFER LENGTH field may allow up to 256 blocks or 256 bytes of data to be transferred 
by one command. 


In commands that use multiple bytes for the TRANSFER LENGTH field, a transfer length of zero specifies that no data transfer 
shall take place. A value of one or greater specifies the number of blocks or bytes that shall be transferred. Refer to the specific 
command description for further information. 


2.2.5 PARAMETER LIST LENGTH 


The PARAMETER LIST LENGTH field is used to specify the number of bytes sent from the Data-Out Buffer. This field is typically 
used in CDBs for parameters that are sent to a device server (e.g., mode parameters, diagnostic parameters, log parameters). A 
parameter list length of zero specifies that no data shall be transferred. This condition shall not be considered as an error, unless 
otherwise specified. 


2.2.6 ALLOCATION LENGTH 


The ALLOCATION LENGTH field specifies the maximum number of bytes that an application client has allocated in the Data-In 
Buffer. An allocation length of zero specifies that no data shall be transferred. This condition shall not be considered as an error. 
The device server shall terminate transfers to the Data-In Buffer when the number of bytes specified by the ALLOCATION 
LENGTH field have been transferred or when all available data have been transferred, whichever is less. The allocation length is 
used to limit the maximum amount of variable length data (e.g., mode data, log data, diagnostic data) returned to an application 
client. If the information being transferred to the Data-In Buffer includes fields containing counts of the number of bytes in some 
or all of the data, then the contents of these fields shall not be altered to reflect the truncation, if any, that results from an 
insufficient ALLOCATION LENGTH value, unless this manual describes the Data-In Buffer format states otherwise. 


If the amount of information to be transferred exceeds the maximum value that the ALLOCATION LENGTH field is capable of 
specifying, the device server shall transfer no data and terminate the command with CHECK CONDITION status, with the sense 
key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 
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CONTROL 
CONTROL byte has the same definition for all commands. 


All CDBs shall contain a CONTROL byte (see table 10). The location of the CONTROL byte within a CDB depends on the CDB 
format (see 2.1.2 and 2.1.3). 

















Table 10 CONTROL byte 
Bit 7 6 4 2 1 0 
Vendor Specific Reserved NACA Obsolete Obsolete 


























All SCSI transport protocol standards shall define the functionality needed for a logical unit to implement the NACA bit. 


NACA (Normal ACA) bit 


The NACA (Normal ACA) bit specifies whether an auto contingent allegiance (ACA) is established if the command returns with CHECK CONDI- 
TION status. An NACA bit set to one specifies that an ACA shall be established. 


0 


2.2.8 


An NACA bit set to zero specifies that an ACA shall not be established. The actions for ACA are specified in SAM-5. Actions that may be 
required when an ACA is not established are described in SAM-5. All logical units shall implement support for the NACA value of zero 
and may support the NACA value of one (i.e., ACA). The ability to support a NACA value of one is indicated with the NORMACA bit in the 
standard INQUIRY data (see clause 3.6.2) 


If the NACA bit is set to one but the logical unit does not support ACA, the command shall be terminated with CHECK CONDITION status, 
with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


GROUPING FUNCTION 


A grouping function is a function that collects information about attributes associated with commands (i.e., information about 
commands with the same group value are collected into the specified group). The definition of the attributes and the groups is 
outside the scope of this manual. Groups are identified with the GROUP NUMBER field in the CDB of certain commands (e.g., the 
WRITE (10) command (see 3.60)). 


The 


collection of this information is outside the scope of this manual (e.g., the information may not be transmitted using any 


SCSI protocols). 


Support for the grouping function is indicated in the GROUP_SUP bit in the Extended INQUIRY Data VPD page (see 5.4.9). 
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2.3 Parameter Rounding 


Certain parameters sent to a SCSI target port with various commands contain a range of values. Targets may choose to 
implement only selected values from this range. When the target receives a value that it does not support, it either rejects the 
command (CHECK CONDITION status with Illegal Request Sense key) or it rounds the value received to a supported value. The 
target shall reject unsupported values unless rounding is permitted in the description of the parameter. 


Rounding of parameter values, when permitted (Rounding is enabled by MODE SELECT command, page code 00h, byte 2, bit 2) 
shall be performed as follows: 


a SCSI target port that receives a parameter value that is not an exact supported value shall adjust the value to one that it 
supports and shall return CHECK CONDITION status with a sense key of Recovered Error. The additional sense code shall be set to 
Rounded Parameter. The initiator is responsible to issue an appropriate command to learn what value the target has selected. 


Implementor’s Note: Generally, the target should adjust maximum-value fields down to the next lower supported value than 
the one specified by the initiator. Minimum-value fields should be rounded up to the next higher supported value than the one 
specified by the initiator. In some cases, the type of rounding (up or down) is explicitly specified in the description of the 
parameter. 
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2.4 Sense data 


2.4.1 Sense data introduction 


Sense data shall be returned in the same |_T_L_Q nexus transaction as a CHECK CONDITION status and as parameter data in 
response to the REQUEST SENSE command. Sense data returned in the same I_T_L_Q nexus transaction as a CHECK CONDITION 
status shall be either fixed or descriptor format sense data format based on the value of the D_SENSE bit in the Control mode 
page. The REQUEST SENSE command may be used to request either the fixed format sense data or the descriptor format sense 


data.f 


The first byte of all sense data contains the RESPONSE CODE field that indicates the error type and format of the sense data (see 
table 11). 



































Table 11 Sense data response codes 
Response Error type Sense data format 
Code Description Reference Description Reference 
00h - 6Fh Reserved 
70h Current 2.4.1.3 Fixed 2.4.1.2 
71h Deferred 2.4.1.4 Fixed 2.4.1.2 
72h Current 2.4.1.3 Descriptor 2.4.1.1 
73h Deferred 2.4.1.4 Descriptor 2.4.1.1 
74h - 7Eh Reserved 
7Fh Vendor specific 














The RESPONSE CODE field shall be set to 70h in all unit attention sense data in which: 
a) The ADDITIONAL SENSE CODE field is set to 29h; or 
b) The additional sense code is set to MODE PARAMETERS CHANGED. 
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2.4.1.1 Descriptor format sense data 


2.4.1.1.1 Descriptor format sense data overview 


The descriptor format sense data for response codes 72h (current errors) and 73h (deferred errors) is defined in table 12. 


Table 12 Descriptor format sense data 










































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 Reserved RESPONSE CODE (72h or 73h) 
1 Reserved SENSE KEY 
2 ADDITIONAL SENSE CODE 
3 ADDITIONAL SENSE CODE QUALIFIER 
4 
Reserved 
6 
7 ADDITIONAL SENSE LENGTH (n-7) 
Sense Data Descriptor(s) 
8 (MSB) 
Sense Data Descriptor (first) (see table 13) 
(LSB) 
(MSB) 
Sense Data Descriptor (last) (see table 13) 
n (LSB) 
RESPONSE CODE field 


The contents of the RESPONSE CODE field indicate the error type and format of the sense data (see 2.4.1). For descriptor format sense data, the 
RESPONSE CODE field shall be set to 72h or 73h. 


SENSE KEY, ADDITIONAL SENSE CODE and ADDITIONAL SENSE CODE QUALIFIER fields 


The SENSE KEY, ADDITIONAL SENSE CODE and ADDITIONAL SENSE CODE QUALIFIER fields provide a hierarchy of information. The hierarchy 
provides a top-down approach for an application client to determine information relating to the error and exception conditions. 


SENSE KEY field 


The SENSE KEY field indicates generic information describing an error or exception condition. The sense keys are defined in 2.4.1.5. 


ASC (ADDITIONAL SENSE CODE) field 


The ADDITIONAL SENSE CODE (ASC) field indicates further information related to the error or exception condition reported in the SENSE KEY 
field. Support of the additional sense codes not required by this manual is optional. A list of additional sense codes is in 2.4.1.5. If the device 
server does not have further information related to the error or exception condition, the additional sense code shall be set to zero. 


ASCQ (ADDITIONAL SENSE CODE QUALIFIER) field 


The ADDITIONAL SENSE CODE QUALIFIER (ASCQ) field indicates detailed information related to the additional sense code. If the error or excep- 
tion condition is reported by the device server, the value returned shall be as specified in 2.4.1.5. If the device server does not have detailed 
information related to the error or exception condition, the additional sense code qualifier shall be set to zero. 


ADDITIONAL SENSE LENGTH field 


The ADDITIONAL SENSE LENGTH field indicates the number of additional sense bytes that follow. The additional sense length shall be less than 
or equal to 244 (i.e., limiting the total length of the sense data to 252 bytes). If the sense data is being returned as parameter data by a REQUEST 
SENSE command, then the relationship between the ADDITIONAL SENSE LENGTH field and the CDB ALLOCATION LENGTH field is defined in 
2.2.6. 
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SENSE DATA DESCRIPTORS field 


Sense data descriptors (see table 13) provide specific sense information. A given type of sense data descriptor shall be included in the sense 
data only when the information it contains is valid. 


Table 13 Sense data descriptor format 












































Bit 7 () 5 4 3 2 1 0 
Byte 
0 DESCRIPTOR TYPE 
1 ADDITIONAL LENGTH (n-1) 
2 (MSB) 
SENSE DATA DESCRIPTOR SPECIFIC 
n (LSB) 








DESCRIPTOR TYPE field 


The DESCRIPTOR TYPE field contains a type code (see table 14) that identifies the type of sense data descriptor. No more than one sense data 
descriptor of each type shall be included in the descriptor format sense data. 


Table 14 Sense data descriptor types 








Type Description Reference 
00h Information 2.4.1.1.2 
Oth Command specific information 2.4.1.1.3 
02h Sense key specific 2.4.1.1.4 
03h Field replaceable unit 2.4.1.1.5 
04h Stream commands SSC-3 
05h Block commands SBC-4 
06h OSD object identification OSD 
07h OSD response integrity check value OSD 
08h OSD attribute identification OSD 
09h ATA Return SAT 
OAh Another Progress indication 2.4.1.1.6 

OBh - 7Fh Reserved 
80h - FFh Vendor specific 2.4.1.1.7 

















ADDITIONAL LENGTH field 
The ADDITIONAL LENGTH field indicates the number of sense data descriptor specific bytes that follow in the sense data descriptor. 
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defined in a command standard. 


General Concepts 


Information sense data descriptor 
The information sense data descriptor (see table 15) provides information that is device-type or command specific and is 


















































Table 15 Information sense data descriptor format 

Bit 7 6 5 4 3 2 1 0 
Byte 

0 DESCRIPTOR TYPE (00h) 

1 ADDITIONAL LENGTH (0Ah) 

2 VALID (1b) Reserved 

3 Reserved 

4 (MSB) 

INFORMATION 
11 (LSB) 








DESCRIPTOR TYPE and ADDITIONAL LENGTH fields 


The DESCRIPTOR TYPE and ADDITIONAL LENGTH fields are described in 2.4.1.1.1. For the information sense data descriptor, the DESCRIPTOR 
TYPE field shall be set to 00h and the ADDITIONAL LENGTH field shall be set to OAh. 


VALID bit 


The VALID bit shall be set to one. 


NOTE 


INFORMATION field 
The contents of the INFORMATION field are device-type or command specific and are defined in a command standard. When a four byte quan- 


In the fixed format sense data, the VALID bit indicates whether the contents of the INFORMATION field 
is valid as defined by a command standard. Since the contents of the INFORMATION field are valid 
whenever an information sense data descriptor is included in the sense data, the only legal value for 


the VALID bit is set to one. 


tity is stored in the INFORMATION field, the first four bytes shall be zero. 


2.4.1.1.3 


The commana-specific information sense data descriptor (see table 16) provides information that depends on the command on 


Command-specific information sense data descriptor 


which the exception condition occurred. 















































Table 16 Command-specific information sense data descriptor format 

Bit 7 6 5 4 3 2 1 0 
Byte 

0 DESCRIPTOR TYPE (01h) 

1 ADDITIONAL LENGTH (0Ah) 

2 Reserved 

3 Reserved 

4 (MSB) 

COMMAND SPECIFIC INFORMATION 
11 (LSB) 
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DESCRIPTOR TYPE and ADDITIONAL LENGTH fields 

The DESCRIPTOR TYPE and ADDITIONAL LENGTH fields are described in 2.4.1.1.1. For the command-specific information sense data descriptor, 
the DESCRIPTOR TYPE field shall be set to 01h and the ADDITIONAL LENGTH field shall be set to OAh. 

COMMAND-SPECIFIC INFORMATION field 


The COMMAND-SPECIFIC INFORMATION field contains information that depends on the command on which the exception condition occurred. 
When a four byte quantity is stored in the COMMAND-SPECIFIC INFORMATION field, the first four bytes shall be zero. 


Further meaning for the COMMAND-SPECIFIC INFORMATION field is defined within the command description in the appropriate command 
standard (e.g., see SBC-4 for the REASSIGN BLOCKS commands, or SPC-5 for the EXTENDED COPY command). 


2.4.1.1.4 Sense key specific sense data descriptor 


2.4.1.1.4.1 Sense key specific sense data descriptor introduction 


The sense key specific sense data descriptor (see table 17) provides additional information about the exception condition. The 
format and content of the sense-key specific data depends on the value in the SENSE KEY field (see 2.4.1.1.1). 


Table 17 Sense key specific sense data descriptor format 





























Bit 7 6 5 4 3 2 1 0 
Byte 

0 DESCRIPTOR TYPE (02h) 

1 ADDITIONAL LENGTH (06h) 

2 Reserved 

3 Reserved 

4 SKSV (1b) 

5 SENSE KEY SPECIFIC 

6 

7 Reserved 














DESCRIPTOR TYPE and ADDITIONAL LENGTH fields 
The DESCRIPTOR TYPE and ADDITIONAL LENGTH fields are described in 2.4.1.1.1. For the sense-key specific sense data descriptor, the DESCRIP- 
TOR TYPE field shall be set to 01h and the ADDITIONAL LENGTH field shall be set to 06h. 
SKSV (Sense-key specific valid) bit 
The sense-key specific valid (SKSV) bit shall be set to one. 
NOTE _ Inthe fixed format sense data, the SKSV bit indicates whether the contents of the SENSE KEY SPECIFIC 
field are valid as defined by a command standard. Since the contents of the SENSE KEY SPECIFIC field 


are valid whenever a sense key specific sense data descriptor is included in the sense data, the only 
legal value for the SKSV bit is set to one. 
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The definition of the SENSE KEY SPECIFIC field (see table 18) is determined by the value of the SENSE KEY field (see 2.4.1.1.1). 


Table 18 Sense key specific field definitions 

















Sense Key Sense Key Specific Field Definition Reference 
ILLEGAL REQUEST Field pointer 2.4.1.1.4.2 
HARDWARE ERROR, 
MEDIUM ERROR, or Actual retry count 2.4.1.1.4.3 
RECOVERED ERROR 
NO SENSE or NOT READY Progress indication 2.4.1.1.4.4 
COPY ABORTED Segment pointer 2.4.1.1.4.5 
UNIT ATTENTION Unit attention condition queue overflow 2.4.1.1.4.6 
All other sense keys i sense key specific sense data descriptor shall not appear in the descriptor format sense 
ata and the SKSV bit (see 2.4.1.2) shall be set to zero in the fixed format sense data. 














2.4.1.1.4.2 Field pointer sense key specific data 


If the SENSE KEY is ILLEGAL REQUEST, then the SENSE KEY SPECIFIC field shall be as shown in table 19. 


Table 19 Field pointer sense key specific data 
































Bit 7 6 5 4 3 2 1 0 
Byte 
0 SKSV (1b) C/D Reserved BPV BIT POINTER 
1 (MSB) 
FIELD POINTER 
2 (LSB) 
SKSV bit 


The SKSV bit is described in 2.4.1.1.4.1 for descriptor format sense data and in 2.4.1.2 for fixed format sense data. 


C/D (Command Data) bit 
0 AC/D bit set to zero indicates that the illegal parameter is in the data parameters sent by the application client in the Data-Out Buffer. 


1 AC/D bit set to one indicates that the illegal parameter is in the CDB. 


BPV (Bit Pointer Valid) bit 
0 A BPV bit set to zero indicates that the value in the BIT POINTER field is not valid. 


1 A BPV bit set to one indicates that the BIT POINTER field specifies which bit of the byte designated by the FIELD POINTER field is in error. 
When a multiple-bit field is in error, the BIT POINTER field shall point to the first bit (i.e., the left-most bit) of the field. 


FIELD POINTER field 


The FIELD POINTER field indicates which byte of the CDB or of the parameter data was in error. Bytes are numbered starting from zero, as 
shown in the tables describing the commands and parameters. When a multiple-byte field is in error, the field pointer shall point to the first 
byte (i.e., the left-most byte) of the field. If several consecutive bytes are reserved, each shall be treated as a single-byte field. 


NOTE — The bytes identified as being in error are not necessarily the bytes that need to be changed to correct 
the problem. 
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2.4.1.1.4.3 Actual retry count sense key specific data 


If the sense key is HARDWARE ERROR, MEDIUM ERROR, or RECOVERED ERROR, then the SENSE KEY SPECIFIC field shall be as shown in table 20. 


Table 20 Actual retry count sense key specific data 















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 SKSV (1b) Reserved 
1 (MSB) 
ACTUAL RETRY COUNT se Tl 
2 (LSB) 
SKSV bit 


The SKSV bit is described in 2.4.1.1.4.1 for descriptor format sense data and in 2.4.1.2 for fixed format sense data. 


ACTUAL RETRY COUNT field 


The ACTUAL RETRY COUNT field returns vendor specific information on the number of retries of the recovery algorithm used in attempting to 
recover an error or exception condition. 


NOTE _ This field should be computed in the same way as the retry count fields within the Read-Write Error 
Recovery mode page. 


2.4.1.1.4.4 Progress indication sense key specific data 


If the sense key is NO SENSE or NOT READY, the SENSE KEY SPECIFIC field shall be as shown in table 21. 









































Table 21 Progress indication sense key specific data 

Bit 7 6 5 4 3 2 1 0 
Byte 

0 SKSV (1b) Reserved 

1 (MSB) 

oo PROGRESS INDICATION 

2 (LSB) 

SKSV bit 


The SKSV bit is described in 2.4.1.1.4.1 for descriptor format sense data and in 2.4.1.2 for fixed format sense data. 


PROGRESS INDICATION field 


The PROGRESS INDICATION field is a percent complete indication in which the returned value is a numerator that has 65 536 (10000h) as its 
denominator. The progress indication shall be based upon the total operation. 


NOTE The progress indication should be time related, however this is not an absolute requirement. (E.g., 
since format time varies with the number of defects encountered, etc., it is reasonable for the device 
server to assign values to various steps within the process. The granularity of these steps should be 
small enough to provide reasonable assurances to the application client that progress is being made.) 
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2.4.1.1.4.5 Segment pointer sense key specific data 


If the sense key is COPY ABORTED, the SENSE KEY SPECIFIC field shall be as shown in table 22. 


Table 22 Segment pointer sense key specific data 















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 SKSV (1b) Reserved SD Reserved BPV BIT POINTER 
1 (MSB) 
FIELD POINTER —_— = =] 
2 (LSB) 
SKSV bit 


The SKSV bit is described in 2.4.1.1.4.1 for descriptor format sense data and in 2.4.1.2 for fixed format sense data. 


SD (SEGMENT DESCRIPTOR) bit 


The SD bit indicates whether the field pointer is relative to the start of the parameter list or to the start of a segment descriptor. 


0 AnSD bit set to zero indicates that the field pointer is relative to the start of the parameter list. 


1 An SD bit set to one indicates that the field pointer is relative to the start of the segment descriptor indicated by the third and fourth 
bytes of the COMMAND-SPECIFIC INFORMATION field. 


BPV (BIT POINTER VALID) bit 
0 =A BPV bit set to zero indicates that the value in the BIT POINTER field is not valid. 
1 A BPV bit set to one indicates that the BIT POINTER field specifies which bit of the byte designated by the FIELD POINTER field is in error. 


When a multiple-bit field is in error, the BIT POINTER field shall point to the most-significant (i-e., left-most) bit of the field. 


FIELD POINTER field 
The FIELD POINTER field indicates which byte of the parameter list or segment descriptor was in error. 


If the parameter list is in excess of 65 528 bytes in length and SD is set to zero, the FIELD POINTER value may not fit in two bytes provided by the 
sense key specific sense data descriptor. 


2.4.1.1.4.6 Unit attention condition queue overflow sense key specific data 


If the sense key is UNIT ATTENTION, the SENSE KEY SPECIFIC field shall be as shown in table 23 


Table 23 Unit attention condition queue overflow sense key specific data 





Bit 7 6 5 4 3 2 1 0 
Byte 




















0 SKSV (1b) Reserved OVERFLOW 
1 














Reserved 
2 














SKSV bit 
The SKSV bit is described in 2.4.1.1.4.1 for descriptor format sense data and in 2.4.1.2 for fixed format sense data. 
OVERFLOW bit 


O = An overFLow bit set to zero indicates that the unit attention condition queue has not overflowed. 


1 An OVERFLOW bit set to one indicates that the unit attention condition queue has overflowed. 
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2.4.1.1.5 


Field replaceable unit sense data descriptor 


The field replaceable unit sense data descriptor (see table 24) provides information about a component that has failed. 






































Table 24 Field replaceable unit sense data descriptor format 

Bit 7 6 5 4 3 2 1 0 
Byte 

0 DESCRIPTOR TYPE (03h) 

1 ADDITIONAL LENGTH (02h) 

2 Reserved 

3 FIELD REPLACEABLE UNIT CODE 














DESCRIPTOR TYPE and ADDITIONAL LENGTH fields 


The DESCRIPTOR TYPE and ADDITIONAL LENGTH fields are described in 2.4.1.1.1. For the field replaceable unit sense data descriptor, the 
DESCRIPTOR TYPE field shall be set to 03h and the ADDITIONAL LENGTH field shall be set to 02h. 


FIELD REPLACEABLE UNIT CODE field 


Non-zero values in the FIELD REPLACEABLE UNIT CODE field are used to identify a component that has failed. A value of zero in this field indi- 
cates that no specific component has been identified to have failed or that the data is not available. The format of this information is not speci- 
fied by this manual. Additional information about the field replaceable unit may be available in the ASCII Information VPD page, if supported 
by the device server. 


2.4.1.1.6 


Progress indication sense data descriptor 


General Concepts 


If the sense key is set to NO SENSE or NOT READY, the progress indication sense data descriptor (see table 25) may be used to 
provide a progress indication for one operation other than the one described by the non-descriptor fields in 2.4.1.1.1. The sense 
data should include one progress indication sense data descriptor for each operation for which the device server is able to report 
progress other than the operation described by the non-descriptor fields in 2.4.1.1.1. 















































Table 25 Progress indications sense data descriptor format 

Bit 7 6 5 4 3 2 1 0 
Byte 

0 DESCRIPTOR TYPE (OAh) 

1 ADDITIONAL LENGTH (06h) 

2 sense key 

3 additional sense code 

4 additional sense code qualifier 

5 Reserved 

6 MSB 

progress indication 
7 LSB 














DESCRIPTOR TYPE and ADDITIONAL LENGTH fields 
The DESCRIPTOR TYPE field and ADDITIONAL LENGTH field are described in 2.4.1.1.1. 


For the progress indications sense data descriptor: 


a) the DESCRIPTORTYPE field shall be set to OAh; and 
b) the ADDITIONAL LENGTH field shall be set to 06h. 
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SENSE KEY field 

The SENSE KEY field indicates the operation for which this progress indication sense data descriptor provides a progress indication. A list of 
sense key values is in 2.4.1.5. 

ADDITIONAL SENSE CODE field 

The ADDITIONAL SENSE CODE (ASC) field indicates the operation for which this progress indication sense data descriptor provides a progress 
indication. A list of additional sense codes is in 2.4.1.6. 

ADDITIONAL SENSE CODE QUALIFIER field 


The ADDITIONAL SENSE CODE QUALIFIER (ASCQ) field indicates detailed information related to the additional sense code for the operation for 
which this progress indication sense data descriptor provides a progress indication. The value returned in the ADDITIONAL SENSE CODE QUAL- 
IFIER (ASCQ) field shall be as specified in 2.4.1.6. 


PROGESS INDICATION field 


The PROGESS INDICATION field indicates a percent complete for the operation indicated by the SENSE KEY field, the ADDITIONAL SENSE CODE 
field, and the ADDITIONAL SENSE CODE QUALIFIER field. The value in the PROGESS INDICATION field shall be as defined in 2.4.1.1.4.4. 


2.4.1.1.7. Vendor specific sense data descriptors 
Vendor specific sense data descriptors (see table 26) contain vendor specific data that further defines the nature of the exception condition. 


Table 26 Vendor specific sense data descriptor format 

















Bit 7 6 5 4 3 2 1 0 
Byte 
0 DESCRIPTOR TYPE (80h - FFh) 
1 ADDITIONAL LENGTH (n-1) 
2 (MSB) 
VENDOR SPECIFIC 
n (LSB) 














DESCRIPTOR TYPE and ADDITIONAL LENGTH fields 


The DESCRIPTOR TYPE and ADDITIONAL LENGTH fields are described in 2.4.1.1.1. For the vendor specific sense data descriptor, the DESCRIP- 
TOR TYPE field shall be set to a value between 80h and FFh, inclusive. 
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2.4.1.2 Fixed format sense data 
The fixed format sense data for response codes 70h (current errors) and 71h (deferred errors) is defined in table 27. 


Table 27 Fixed format sense data 
























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 VALID RESPONSE CODE (70h OR 71h) 

1 Obsolete 

2 FILEMARK EOM ILI Reserved SENSE KEY 

3 (MSB) 

INFORMATION 

6 (LSB) 

7 ADDITIONAL SENSE LENGTH (n-7) 

8 (MSB) 


COMMAND-SPECIFIC INFORMATION 


























SENSE KEY SPECIFIC 


11 (LSB) 
12 ADDITIONAL SENSE CODE 

13 ADDITIONAL SENSE CODE QUALIFIER 

14 FIELD REPLACEABLE UNIT CODE 

15 SKSV (MSB) 




















17 (LSB) 
18 (MSB) 
ADDITIONAL SENSE BYTES 
n (LSB) 
VALID bit 


0 = AVALID bit set to zero indicates that the INFORMATION field is not defined in this manual or any command standard. 


1 A VALID bit set to one indicates the INFORMATION field contains valid information as defined in this manual or a command standard. 


RESPONSE CODE field 


The contents of the RESPONSE CODE field indicate the error type and format of the sense data (see 2.4.1). For fixed format sense data, the 
RESPONSE CODE field shall be set to 70h or 71h. 


FILE MARK bit 
See the SSC-3 READ and SPACE commands for examples of FILEMARK bit usage. 


EOM (End-of-Medium) bit 
See the SSC-3 READ, SPACE, and WRITE commands for examples of end-of-medium (EOM) bit usage. 


ILI (Incorrect length indicator) Bit 
See the SBC-4 READ LONG, SBC-4 WRITE LONG, and SSC-3 READ commands and for examples of incorrect length indicator (ILI) bit usage. 
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SENSE KEY, ADDITONAL SENSE CODE, and ADDITIONAL SENSE CODE QUALIFIER fields 
The SENSE KEY, ADDITIONAL SENSE CODE, and ADDITIONAL SENSE CODE QUALIFIER fields are described in 4.5.2.1. 


INFORMATION field 
The contents of the INFORMATION field is device-type or command specific and is defined within the appropriate standard for the device type 
or command of interest. targets shall implement the INFORMATION field. Unless specified otherwise, this field contains: 


a) the unsigned LOGICAL BLOCK ADDRESS associated with the sense key, for direct-access devices (device type 0), write-once devices 
(device type 4), CD-ROM devices (device type 5), and optical memory devices (device type 7); 

b) the difference (residue) of the requested length minus the actual length in either bytes or blocks, as deter-mined by the command, for 
sequential-access devices (device type 1), printer devices (device type 2), processor devices (device type 3) and some direct access 
device commands, except as defined for d) below. Negative values are indicated by two's complement notation; 

c) the difference (residue) of the requested number of blocks minus the actual number of blocks copied or compared for the current 
segment descriptor of a COPY, COMPARE, COPY AND VERIFY, or Extended COPY command; or 

d) for sequential-access devices operating in buffered modes 1h or 2h that detect an unrecoverable write error when unwritten data 
blocks, filemarks, or setmarks remain in the buffer, the value of the information field for all commands shall be: 


A) _ the total number of data blocks, filemarks, and setmarks in the buffer if the device is in fixed block mode (block length field of the 
MODE SENSE block descriptor is non-zero and the fixed bit of the WRITE command is one); or 


B) the number of bytes in the buffer, including filemarks and setmarks, if the device is in variable mode (the fixed bit of the WRITE 
command is zero). 
ADDITIONAL SENSE LENGTH field 


The ADDITIONAL SENSE LENGTH field indicates the number of additional sense bytes that follow. The additional sense length shall be less than 
or equal to 244 (i.e., limiting the total length of the sense data to 252 bytes). If the sense data is being returned as parameter data by a REQUEST 
SENSE command, then the relationship between the ADDITIONAL SENSE LENGTH field and the CDB ALLOCATION LENGTH field is defined in 
2.2.6. 

COMMAND-SPECIFIC INFORMATION field 


The COMMAND-SPECIFIC INFORMATION field contains information that depends on the command on which the exception condition occurred. 


FIELD REPLACEABLE UNIT CODE field 
The FIELD REPLACEABLE UNIT CODE field is described in 2.4.1.1.5. 


SKSV (Sense-key Specific Valid) bit 


1 A sense-key specific valid (SKSV) bit set to one indicates the SENSE KEY SPECIFIC field contains valid information as defined in this man- 
ual. 


0 AnSKSV bit set to zero indicates that the SENSE KEY SPECIFIC field is not as defined by this manual. 
SENSE KEY SPECIFIC field 
The SENSE KEY SPECIFIC field is described in 2.4.1.1.4. 


The additional sense bytes may contain vendor specific data that further defines the nature of the exception condition. 


2.4.1.3 Current errors 


Response codes 70h and 72h (current error) indicate that the sense data returned is the result of an error or exception condition on 
the task that returned the CHECK CONDITION status or a protocol specific failure condition. This includes errors 
generated during processing of the command. It also includes errors not related to any command that are detected 
during processing of acommand (e.g., disk servo-mechanism failure, off-track errors, or power-up test errors). 
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2.4.1.4 


Deferred errors 


Response codes 71h and 73h (deferred error) indicate that the sense data returned is the result of an error or exception condition 
that occurred during processing of a previous command for which GOOD, CONDITION MET, INTERMEDIATE, and 
INTERMEDIATE-CONDITION MET status has already been returned. Such commands are associated with the use of the 
immediate bit and with some forms of caching. Device servers that implement these features shall implement deferred error 
reporting. 


The deferred error may be indicated by returning CHECK CONDITION status to an application client accessed through a defined 
|_T nexus as described in this subclause. 


If the task terminates with CHECK CONDITION status and the sense data describes a deferred error, the command for the 
terminated task shall not have been processed. After the device server detects a deferred error condition, it shall return a 
deferred error according to the following rules: 


a) 


b) 


If no external intervention is necessary to recover a deferred error, a deferred error indication shall not be returned unless 
required by the error handling parameters of a MODE SELECT command. The occurrence of the error may be logged; 


If it is possible to associate a deferred error with an |_T nexus and with a particular function or a particular subset of data, and the error is 
either unrecovered or required to be reported by the mode parameters, then a deferred error indication shall be returned for a com- 
mand received on the |_T nexus associated with the deferred error. If an application client request received on an |_T nexus other than 
the I_T nexus associated with the deferred error attempts to access the particular function or subset of data associated with the deferred 
error and the TST field equals 000b, then the device server shall respond to the command with a BUSY or ACA ACTIVE status according 
to the requirements in SAM-5. If an application client request received on an |_T nexus other than the |_T nexus associated with the 
deferred error attempts to access the particular function or subset of data associated with the deferred error and the TST field equals 
001b, then the command attempting the access shall not be blocked by the deferred error and the cause of the deferred error may result 
in an error being reported for the command attempting the access; 


If the device server is unable to associate a deferred error with an I_T nexus or with a particular subset of data, the device server shall 
return a deferred error for one command received on each |_T nexus. If multiple deferred errors have accumulated for an |_T nexus, only 
the last error shall be returned; 


If the SCSI target device is unable to associate a deferred error with a particular logical unit, it shall establish a deferred error for every 
logical unit and shall return the deferred error for one command for each logical unit received on each appropriate |_T nexus; or 


If a task has never entered the enabled task state, and a deferred error occurs, the task shall be terminated with CHECK CONDITION sta- 
tus and deferred error information returned in the sense data. If a deferred error occurs after a task has entered the enabled task state 
and the task is affected by the error, the task shall be terminated with CHECK CONDITION status and the current error information shall 
be returned in the sense data. In this case, if the current error information does not adequately define the deferred error condition, a 
deferred error may be returned after the current error information has been returned. If a deferred error occurs after a task has entered 
the enabled task state and the task completes successfully, the device server may choose to return the deferred error information after 
the completion of the current command in conjunction with a subsequent command that has not begun processing. 


NOTE A deferred error may indicate that an operation was unsuccessful long after GOOD status was 


returned. If the application client is unable to replicate or recover from other sources the data that is 
being written using cached or buffered write operations, then synchronization commands should be 
performed before the critical data is destroyed. This is necessary for actions taken when deferred 
errors occur in the storing of the data. The synchronizing process should provide the necessary 
commands to allow returning CHECK CONDITION status and subsequent returning of deferred error 
sense information after all cached or buffered operations are completed. 
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2.4.1.5 Sense key and sense code definitions 
The sense keys are defined in table 28. 


Table 28 Sense key descriptions 








Sens 
e Description 
Key 
oh NO SENSE: Indicates that there is no specific sense key information to be reported. This may occur for a successful command or 


for a command that receives CHECK CONDITION status because one of the FILEMARK, EOM, or ILI bits is set to one. 


RECOVERED ERROR: Indicates that the command completed successfully, with some recovery action performed by the device 
th server. Details may be determined by examining the additional sense bytes and the INFORMATION field. When multiple recovered 
errors occur during one command, the choice of which error to report (e.g., first, last, most severe) is vendor specific. 


2h NOT READY: Indicates that the logical unit is not accessible. Operator intervention may be required to correct this condition. 











MEDIUM ERROR: Indicates that the command terminated with a non-recovered error condition that may have been caused by a 
3h__| flaw in the medium or an error in the recorded data. This sense key may also be returned if the device server is unable to 
distinguish between a flaw in the medium and a specific hardware failure (i.e., sense key 4h). 


HARDWARE ERROR: Indicates that the device server detected a non-recoverable hardware failure (e.g., controller failure, device 

















= failure, or parity error) while performing the command or during a self test. 
ILLEGAL REQUEST: Indicates that: 
a) The command was addressed to an incorrect logical unit number (see SAM-5); 
b) The command had an invalid task attribute (see SAM-5); 
c) The command was addressed to a logical unit whose current configuration prohibits processing the command; 
5h d) There was an illegal parameter in the CDB; or 
e) There was an illegal parameter in the additional parameters supplied as data for some commands (e.g., PERSISTENT 
RESERVE OUT). 
If the device server detects an invalid parameter in the CDB, it shall terminate the command without altering the medium. If the 
device server detects an invalid parameter in the additional parameters supplied as data, the device server may have already 
altered the medium. 
6h UNIT ATTENTION: Indicates that a unit attention condition has been established (e.g., the removable medium may have been 
changed, a logical unit reset occurred). See SAM-5. 
7h DATA PROTECT: Indicates that a command that reads or writes the medium was attempted on a block that is protected. The read 
or write operation is not performed. 
8h BLANK CHECK: Indicates that a write-once device or a sequential-access device encountered blank medium or format-defined 


end-of-data indication while reading or that a write-once device encountered a non-blank medium while writing. 
9h_ | VENDOR SPECIFIC: This sense key is available for reporting vendor specific conditions. 








COPY ABORTED: Indicates an EXTENDED COPY command was aborted due to an error condition on the source device, the 
destination device, or both. 


ABORTED COMMAND: Indicates that the device server aborted the command. The application client may be able to recover by 
trying the command again. 


Ah 


Bh 





Ch Reserved 





VOLUME OVERFLOW: Indicates that a buffered SCSI device has reached the end-of-partition and data may remain in the buffer 
Dh that has not been written to the medium. One or more RECOVER BUFFERED DATA command(s) may be issued to read the 
unwritten data from the buffer. (See SSC-3.) 


Eh MISCOMPARE: Indicates that the source data did not match the data read from the medium. 








COMPLETED: Indicates there is command completed sense data (see SAM-5) to be reported. This may occur for a successful 


Fh command. 
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2.4.1.6 Additional Sense and Additional Sense Qualifier codes 


Table 29 lists the Additional Sense (ASC) and Additional Sense Qualifier (ASCQ) codes. Code values are in hexadecimal. 
ANSI standard SPC-5 lists a more complete table. 


NOTE Table 29 is for reference only, as not all drives covered by this manual support all of the codes listed. 
Codes without sense key references may or may not be supported. 


Table 29 Additional Sense and Additional Sense Qualifier codes 














































































































ASC (byte |ASCQ (byte | Description Sense 
12) 13) Key 
00 00 No Additional Sense Information 0 
01 00 No Index/Logical Block Signal 4 
02 00 No SEEK Complete 4 
03 00 Peripheral Device Write Fault 1,3,4 
03 86 Write Fault Data Corruption 

04 00 Logical Unit Not Ready, Cause Not Reportable 2 
04 01 Logical Unit Not Ready, Becoming Ready 2 
04 02 Logical Unit Not Ready, START UNIT Required 2 
04 03 Logical Unit Not Ready, Manual Intervention Required 2 
04 04 Logical Unit Not Ready, Format in Progress 2 
04 09 Logical Unit Not Ready, Self Test in Progress 2 
04 OA Logical Unit Not Ready, NVC recovery in progress after and exception event 2 
04 11 Logical Unit Not Ready, Notify (Enable Spinup) required 2 
04 22 Logical unit not ready, power cycle required 2 
04 FO Logical unit not ready, super certify in progress 2 
08 00 Logical Unit Communication Failure 9,B 
08 01 Logical Unit Communication Time-Out B 
08 02 Logical Unit Communication Parity Error 

09 00 Track Following Error 1,3,4 
09 01 Servo Fault 1,4 
09 04 Head Select Fault 3,4 
09 oD Write to at least one copy of a redundant file failed 1 

09 OE Redundant files have < 50% good copies 1 

09 F8 Calibration is needed but the QST is set without the Recal Only bit 1 

09 FF Servo Cal completed as part of self-test 1 
0A 00 Error Log Overflow 

0A 01 Failed to write super certify log file 3 
0A 02 Failed to read super certify log file 3 
0B 00 Aborted Command B 
0B 01 Warning—Specified Temperature Exceeded 1,6 
0B 02 Warning, Enclosure Degraded 1 
0c 00 Write Error 3 
0c 01 Write Error Recovered With Auto-Reallocation 1 
0c 02 Write Error—Auto Reallocation Failed 3 
0c 03 Write Error—Recommend Reassignment 3 
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Table 29 Additional Sense and Additional Sense Qualifier codes 





























































































































ASC (byte |ASCQ(byte |Description Sense 
12) 13) Key 
0c FF Write Error—Too many error recovery revs 3 
oD 00 Volume Overflow Constants D 
OE 00 Data Miscompare E 
10 00 ID CRC Or ECC Error 

11 00 Unrecovered Read Error 1,3 
11 01 Read Retries Exhausted 

11 02 Error Too Long To Correct 

11 04 Unrecovered Read Error—Auto Reallocation Failed 3 
11 FF Unrecovered Read Error—Too many error recovery revs 3 
12 00 Address Mark Not Found For ID Field 

12 01 Recovered Data Without ECC Using Previous Logical Block ID 

12 02 Recovered Data With ECC Using Previous Logical Block ID 

14 00 Logical Block Not Found 

14 01 Record Not Found 3 
15 00 Random Positioning Error 

15 01 Mechanical Positioning Error 1,3,4 
15 02 Positioning Error Detected By Read Of Medium 

16 00 Data Synchronization Mark Error 1, 3,4 
17 00 Recovered Data With No Error Correction Applied 

17 01 Recovered Data Using Retries 1 
17 02 Recovered Data Using Positive Offset 1 
17 03 Recovered Data Using Negative Offset 1 
17 05 Recovered Data Using Previous Logical Block ID 

17 06 Recovered Data Without ECC—Data Auto Reallocated 

18 00 Recovered Data With ECC 1 
18 01 Recovered Data With ECC And Retries Applied 1 
18 02 Recovered Data With ECC And/Or Retries, Data Auto-Reallocated 1 
18 05 Recovered Data—Recommand Reassignment 

18 06 Recovered Data Using ECC and Offsets 

18 07 Recovered Data With ECC—Data Rewritten 1 
19 00 Defect List Error 1,4 
19 01 Defect List Not Available 

19 02 Defect List Error In Primary List 

19 03 Defect List Error in Grown List 

19 OE Fewer than 50% Defect List Copies 

1A 00 Parameter List Length Error 5 
1B 00 Synchronous Data Transfer Error 

1c 00 Defect List Not Found 1,4 
iG 01 Primary Defect List Not Found 

1C 02 Grown Defect List Not Found 
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Table 29 Additional Sense and Additional Sense Qualifier codes 




















































































































ASC (byte |ASCQ(byte |Description Sense 
12) 13) Key 
1C 83 Seagate Unique Diagnostic Code 

1D 00 Miscompare During Verify Operation E 
1F 00 Number of Defects Overflows the Allocated Space That The Read Defect Command Can Handle | 1 
20 00 Invalid Command Operation Code 5 
20 F3 Invalid linked command operation code 5 
21 00 Logical Block Address Out Of Range D 
24 00 Invalid Field In CDB 5 
24 01 Illegal Queue Type for CDB (Low priority commands must be SIMPLE queue) 5 
24 FO Invalid LBA in linked command 5 
24 F2 Invalid linked command operation code 5 
24 F3 Illegal G->P operation request 5 
25 00 Logical Unit Not Supported 5 
26 00 Invalid Field In Parameter List 5 
26 01 Parameter Not Supported 5 
26 02 Parameter Value Invalid 5 
26 03 Invalid Field Parameter—Threshold Parameter 5 
26 04 Invalid Release of Active Persistent Reserve 5 
26 05 Fail to read valid log dump data 5 
26 97 Invalid Field Parameter—TMS Firmware Tag 

26 98 Invalid Field Parameter—Check Sum 

26 99 Invalid Field Parameter—Firmware Tag 

27 00 Write Protected 7 
29 00 Flashing LED occurred 4 
29 00 Power On, Reset, Or Bus Device Reset Occurred 6 
29 01 Power-On Reset Occurred 6 
29 02 SCSI Bus Reset Occurred 6 
29 03 Bus Device Reset Function Occurred 6 
29 04 Internal Reset Occurred 6 
29 05 Transceiver Mode Changed To Single-Ended 6 
29 06 Transceiver Mode Changed To LVD 6 
29 07 Write Log Dump data to disk successful OR IT Nexus Loss 6 
29 08 Write Log Dump data to disk fail 6 
29 09 Write Log Dump Entry information fail 6 
29 OA Reserved disk space is full 6 
29 0B SDBP test service contained an error, examine status packet(s) for details 6 
29 0c SDBP incoming buffer overflow (incoming packet too big) 6 
29 cD Flashing LED occurred. (Cold reset) 6 
29 CE Flashing LED occurred. (Warm reset) 6 
2A 01 Mode Parameters Changed 6 
2A 02 Log Parameters Changed 6 
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Table 29 Additional Sense and Additional Sense Qualifier codes 




















































































































ASC (byte |ASCQ(byte |Description Sense 
12) 13) Key 
2A 03 Reservations preempted 6 
2A 04 Reservations Released 6 
2A 05 Registrations Preempted 6 
2C 00 Command Sequence Error 5 
2F 00 Tagged Commands Cleared By Another Initiator 6 
31 00 Medium Format Corrupted 3 
31 01 Corruption in R/W format request 3 
31 91 Corrupt World Wide Name (WWN) in drive information file 3 
32 00 No Defect Spare Location Available 4 
32 01 Defect List Update Error 3,4,5 
32 02 No Spares Available—Too Many Defects On One Track 

32 03 Defect list longer than allocated memory 3 
33 00 Flash not ready for access 3 
35 00 Unspecified Enclosure Services Failure 4 
35 01 Unsupported Enclosure Function 5 
35 02 Enclosure Services Unavailable 2 
35 03 Enclosure Transfer Failure 4 
35 04 Enclosure Transfer Refused 4 
37 00 Parameter Rounded 1 
3D 00 Invalid Bits In Identify Message 

3E 03 Logical Unit Failed Self Test 4 
3E 00 Logical Unit Has Not Self Configured Yet 

3F 00 Target Operating Conditions Have Changed 6 
3F 01 Device internal reset occurred 6 
3F 02 Changed Operating Definition 6 
3F 05 Device Identifier Changed 6 
3F OF Echo buffer overwritten B 
3F 80 Buffer contents have changed 1 
3F 90 Invalid APM Parameters 

3F 91 World Wide Name (WWN) Mismatch 6 
40 01 DRAM Parity Error 1,4 
40 02 Spinup Error recovered with retries 1 
42 00 Power-On Or Self-Test Failure 4 
42 OA Port A failed loopback test 4 
42 0B Port B failed loopback test 4 
43 00 Message Reject Error B 
44 00 Internal Target Failure 1,3,4 
44 F2 Data Integrity Check Failed on verify 4 
44 F6 Data Integrity Check Failed during write 4 
44 FF XOR CDB check error 4 
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Table 29 Additional Sense and Additional Sense Qualifier codes 











































































































ASC (byte |ASCQ(byte |Description Sense 
12) 13) Key 
45 00 Select/Reselection Failure B 
47 00 SCSI Parity Error B 
47 03 Information Unit CRC Error B 
47 80 Fibre Channel Sequence Error B 
48 00 Initiator Detected Error Message Received B 
49 00 Invalid Message Received B 
4B 00 Data Phase Error B 
4B 01 Invalid transfer tag B 
4B 02 Too many write data B 
4B 03 ACK NAK Timeout B 
4B 04 NAK received B 
4B 05 Data Offset error B 
4B 06 Initiator response timeout B 
4c 00 Logical Unit Failed Self-Configuration 

4E 00 Overlapped Commands Attempted B 
55 01 XOR Cache is Not Available 

55 04 PRKT table is full 5 
5B! 00 Log Exception 

5B* 01 Threshold Condition Met 

5B* 02 Log Counter At Maximum 

5B* 03 Log List Codes Exhausted 

5C 00 RPL Status Change 6 
5C 01 Spindles Synchronized 

5C 02 Spindles Not Synchronized 

5D 00 Failure Prediction Threshold Exceeded 1,6 
5D FF False Failure Prediction Threshold Exceeded 1,6 
65 00 Voltage Fault 4 
80 00 General Firmware Error Qualifier 9 
80 86 IOEDC Error on Read 9 
80 87 IOEDC Error on Write 9 
80 88 Host Parity Check Failed 9 
80 89 IOEDC Error on Read Detected by Formatter 9 
80 8A Host FIFO Parity Error detected by Common Buffer 9 
80 8B Host FIFO Parity Error detected by frame buffer logic 9 
80 8C Host Data Frame Buffer Parity Error 9 
81 00 Reassign Power—Fail Recovery Failed 

81 00 LA Check Error, LCM bit = 0 4 
81 00 LA Check Error 

B4 00 Unreported Deferred Errors have been logged on log page 34h 6 





[1] Can be supported, but is a factory installed option. 
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Direct Access Block commands (SPC-5 and SBC-4) 


3. Direct Access Block commands (SPC-5 and SBC-4) 


This clause describes the commands supported by Seagate Disk Drives. 


Commands that have been supported prior to this manual being produced and that are now indicated as obsolete will be 
described in this clause as obsolete. However, a description will be provided for such commands. 


Commands that have been declared obsolete by the T10 committee and were never supported by Seagate are not included in 
this manual. Commands that have not been supported in the past, but may be supported in the near future will be included in 


this manual. 


This clause contains information about the commands used by Seagate Fibre Channel and Serial Attached SCSI disk drives. This 


clause is organized to provide rapid access to command information. 


Two types of commands are supported by the drive: commands for all devices; and commands for direct access devices. The 
individual Product Manuals for each Seagate model drive list the Commands and parameter pages that the particular drive 


supports. 


Table 30 Commands sorted by command name 

































































Command type 
Command name OP code [1] All Direct access Giamee 
devices devices Hees 

BACKGROUND CONTROL 9Eh/15h x 3.1 

CHANGE DEFINITION "2! 40h x 3.2 

FORMAT UNIT 04h x 3.3 

GET LBA STATUS 9Eh/12h x 3.4 
GET STREAM STATUS 9Eh/16h x 3.5 

INQUIRY 12h x 3.6 
LOG SELECT 4Ch x 3.7 

LOG SENSE 4Dh x 3.8 
MODE SELECT (6) 15h x 3.9 
MODE SELECT (10) 55h x 3.10 
MODE SENSE (6) 1Ah x 3.11 
MODE SENSE (10) 5Ah x 3.12 
PERSISTENT RESERVE IN 5Eh x 3.13 
PERSISTENT RESERVE OUT 5Fh x 3.14 
READ (6) 08h x 3.15 
READ (10) 28h x 3.16 
READ (12) A8h x 3.17 
READ (16) 88h x 3.18 
READ (32) 7Fh/0009h x 3.19 
READ BUFFER (10) 3Ch x 3.20 
READ BUFFER (16) 9Bh x 3.21 
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Command type 
Command name OP code [1] All Direct access Cane. 
devices devices Deus 
READ CAPACITY (10) 25h x 3.22 
READ CAPACITY (16) 9Eh/10h Xx 3.23 
READ DEFECT DATA (10) 37h x 3.24 
READ DEFECT DATA (12) B7h x 3.25 
READ LONG (10) 3Eh x 3.26 
READ LONG (16) [21 9Eh/11h x 3.27 
REASSIGN BLOCKS 07h x 3.28 
RECEIVE DIAGNOSTIC RESULTS 1Ch x 3.29 
RELEASE (6) "2! 17h x 3.30 
RELEASE (10) "2! 57h x 3.31 
REPORT IDENTIFYING INFORMATION A3h/05h x 3.32 
REPORT LUNS AOh x 3,33 
REPORT SUPPORTED OPERATIONS CODES A3h/0Ch x 3.34 
REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS A3h/0Dh x 3.35 
REPORT TIMESTAMP A3h/0Fh x 3.36 
REQUEST SENSE 03h x 3.37 
RESERVE (6) "2! 16h x 3.38 
RESERVE (10) '! 56h x 3.39 
REZERO UNIT O1h x 3.40 
SANITIZE 48h x 3.41 
SECURITY PROTOCOL IN A2h x 3.42 
SECURITY PROTOCOL OUT B5h x 3.43 
SEEK (6) OBh x 3.44 
SEEK EXTENDED (10) '#) 2Bh x 3.45 
SEND DIAGNOSTIC 1Dh x 3.46 
SET IDENTIFYING INFORMATION A4h/06h x 3.47 
SET TIMESTAMP A4h/0Fh x 3.48 
START/STOP UNIT 1Bh x 3.49 
STREAM CONTROL 9Eh/14h x 3.50 
SYNCHRONIZE CACHE (10) 35h x 3.51 
SYNCHRONIZE CACHE (16) 91h x 3.52 
TEST UNIT READY 00h x 3.53 
UNMAP 42h x 3.54 
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Command type 
Command name OP code [1] All Direct access pause 
devices devices Cer 
VERIFY(10) 2Fh x 3.55 
VERIFY (12) AFh x 3.56 
VERIFY (16) 8Fh x 3.57 
VERIFY (32) 7Fh/000Ah x 3.58 
WRITE (6) OAh x 3.59 
WRITE (10) 2Ah x 3.60 
WRITE (12) AAh x 3.61 
WRITE (16) 8Ah x 3.62 
WRITE (32) 7Fh/O00Bh x 3.63 
WRITE AND VERIFY (10) 2Eh x 3.64 
WRITE AND VERIFY (12) AEh x 3.65 
WRITE AND VERIFY (16) 8Eh x 3.66 
WRITE AND VERIFY (32) 7Fh/000Ch x 3.67 
WRITE ATOMIC (16) 9Ch x 3.68 
WRITE ATOMIC (32) 7Fh/18h x 3.69 
WRITE BUFFER 3Bh x 3.70 
WRITE LONG 3Fh x 3.71 
WRITE LONG (16) 9Fh/11h x 3.72 
WRITE SAME (10) 41h x 3.73 
WRITE SAME (16) 93h x 3.74 
WRITE SAME (32) 7Fh/000Dh x 3.75 
WRITE SCATTERED (16) XXh x X.XX 
WRITE SCATTERED (32) XXh x X.XX 
WRITE STREAM (16) 9Ah x 3.76 
WRITE STREAM (32) 7Fh x 3.77 























[1] Some commands are defined by a combination of operation code and service action. 
The operation code value is shown preceding the slash and the service action value is shown after the slash. 


[2] | Command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 
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3.1 BACKGROUND CONTROL command 


The BACKGROUND CONTROL command (see table 31) is used to request that the device server start or stop host initiated 
advanced background operations (see 5.3.8), if any. 


This command uses the SERVICE ACTION IN (16) CDB format (see SBC-4 - Annex A.2). 


Table 31 BACKGROUND CONTROL command 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (9Eh) 

1 Reserved SERVICE ACTION (15h) 

2 BO_CTL Reserved 

3 BO_TIME 

4 
bese Reserved 
14 
15 CONTROL 














OPERATION CODE field 


The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the value defined in 
table 31. 


SERVICE ACTION field 
The SERVICE ACTION field is defined in defined in 2.2.2 and set to the value defined in table 31. 


BO_CTL field 


The background operation control (BO_CTL) field specifies that the device server shall control host initiated advanced background operations 
as described in SBC-4. The BO_CTL field is described in Table 32. 


Table 32 BO_CTL field 




















Code Description 
00b Do not change host initiated advanced background operations. 
01b Start host initiated advanced background operations. 
10b Stop host initiated advanced background operations. 
11b Reserved 
BO_TIME field 


The background operation time (BO_TIME) field specifies the maximum time that the device server shall have to perform host initiated 
advanced background operations in units of 100 ms (see SBC-4). The BO_TIME field is ignored if the BO_CTL field is not set to 01b. A BO_TIME 
field set to 00h specifies that there is no limit to the time that the device server may perform host initiated advanced background operations. 


CONTROL byte 
The CONTROL byte is defined in Clause 2.2.7. 
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3.2 CHANGE DEFINITION command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


The CHANGE DEFINITION command (see table ) is used to modify the operating definition of the device server(s) with respect to 
commands from the sending initiator or with respect to commands from all initiators. 


Table 33 CHANGE DEFINITION command 
























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (40h) 

1 Reserved 

2 Reserved SAVE 

3 Reserved DEFINITION PARAMETER 

4 Reserved 

5 Reserved 

6 Reserved 

7 Reserved 

8 PARAMETER DATA LENGTH 

9 CONTROL 














If reservations are active, they shall affect the execution of the CHANGE DEFINITION command as follows. If the SCSI device does 
not allow different operating definitions for each initiator, a reservation conflict shall occur when a CHANGE DEFINITION 
command is received from an initiator other than the one holding a logical unit reservation. If any initiator has an extent or 
element reservation on an SCSI device, no other initiator may affect the operating definition of the initiator holding the 
reservation by use of the CHANGE DEFINITION command. 
SAVE bit 

0 A save control bit (SAVE) of zero indicates that the device server shall not save the operating definition. 


1 A Save bit of one indicates that the device server shall save the operating definition in non-volatile memory. 


The definition parameter field is defined in Table 34. 


Table 34 Definition parameter field 


























Value Meaning of definition parameter 

00h Use current operating definition 
03h SCSI-2 operating definition 
04h SCSI-3 operating definition 

01-02h Reserved for historical uses 

05 -3Eh Reserved 
3Fh Manufacturer default definition 

40 - 7Fh Vendor specific 














The current operating definition parameter values establish operating definitions compatible with the applicable SCSI standard. 
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PARAMETER DATA LENGTH field 


The parameter data length field specifies the length in bytes of the parameter data that shall be transferred from the application client to the 
device server. A parameter data length of zero indicates that no data shall be transferred. This condition shall not be considered as an error. 
Parameter data length values greater than zero indicate the number of bytes of parameter data that shall be transferred. 


The parameter data is vendor-specific. 
1) The parameter data may be used to specify a password to validate an operating definition change. 
The CHANGE DEFINITION command causes one of the operating definition modifications listed below: 
a) Change the operating definition of a logical unit relative to all initiators in the system: In this case, the target is capable of 
maintaining a separate operating definition for each logical unit relative to all initiators in the system; or 


b) | Change the operating definition of all logical units in the target relative to all initiators in the system: In this case, the target is capable of 
maintaining only one operating definition. 
2) This manual does not provide a direct means to determine which of the above methods has been implemented. An 
indirect means of determining which method is implemented exists in that the device server is required to inform affected 
initiators of operating definition changes via the unit attention condition. 


3) The modifications listed c) and d) above may result in incompatibilities if other initiators are using a different SCSI version. 


The operating definition is modified after successful completion of the command. The application client should verify the new 
operating definition by issuing an INQUIRY command requesting the implemented operating definition page (see SCSI -3). 


4) The method of changing the operating definition is vendor-specific. Some implementations may require that the target's 
operating mode be reinitialized as if a power-up or hard reset had occurred. Other implementations may modify only 
those operating definitions that are affected by the CHANGE DEFINITION command. 


If the CHANGE DEFINITION command is not executed successfully for any reason, the operating definition shall remain the same 
as it was before the CHANGE DEFINITION command was attempted. If it is impossible to return to the previous operating 
definition, a unit attention condition shall be generated. 


5) The present operating definition of the target may always be interrogated through the INQUIRY command. When an 
SCSI-3 target has its operating definition changed to an older SCSI operating definition, certain changes are needed to 
promote compatibility with preexisting older SCSI initiators. 


After a power-on condition or a hard reset condition, the target shall set its initial operating definition of the device server(s) to 
the last saved value (if saving is implemented), or its default value (if saving is not implemented). 


CONTROL byte 
The CONTROL byte is defined in Clause 2.2.7. 
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3.3 FORMAT UNIT command 


3.3.1 FORMAT UNIT command overview 


The FORMAT UNIT command (see table 35) requests that the device server format the medium into application client accessible 
logical blocks as specified in the number of blocks and block length values received in the last mode parameter block descriptor 
(see 5.3.4) in a MODE SELECT command (see 3.9 and 3.10). In addition, the device server may certify the medium and create 
control structures for the management of the medium and defects. The degree that the medium is altered by this command is 
vendor-specific. 


If a device server receives a FORMAT UNIT command before receiving a MODE SELECT command with a mode parameter block 
descriptor the device server shall use the number of blocks and block length at which the logical unit is currently formatted (i.e., 
no change is made to the number of blocks and the block length of the logical unit during the format operation). 


Table 35 FORMAT UNIT command 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (04h) 

1 FMTPINFO LONG-LIST | FMTDATA CMPLIST DEFECT LIST FORMAT 

2 Vendor Specific 

3 Reserved 

4 Reserved FFMT 

5 CONTROL 


While performing a format operation, the device server shall respond to commands attempting to enter into the task set except 
INQUIRY commands, REPORT LUNS commands, and REQUEST SENSE commands with CHECK CONDITION status with the sense 
key set to NOT READY and the additional sense code set to LOGICAL UNIT NOT READY, FORMAT IN PROGRESS. Handling of 
commands already in the task set is vendor-specific. If the device server receives an INQUIRY command, a REPORT LUNS 
commands, or a REQUEST SENSE command, then the device server shall process the command. The device server shall return 
data for an INQUIRY command based on the condition of the SCSI target device before beginning the FORMAT UNIT command 
(i.e., INQUIRY data shall not change until after successful completion of a format operation). The processing of commands in the 
task set when a FORMAT UNIT command is received is vendor specific. 
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FMTPINFO (Format Protection Information) field 


The format protection information (FMTPINFO) field (see table 41) in combination with the PROTECTION FIELD USAGE field (see 3.3.3) specifies 
whether or not the device server enables or disables the use of protection information. 


When protection information is written during a FORMAT UNIT command (i.e., the FMTPINFO bit is set to one) protection information shall be 
written to a default value of FFFFFFFF_FFFFFFFFh. 


LONGLIST bit 
If the FMTDATA bit is set to zero, the LONGLIST bit shall be ignored. 
0 ALONGLIST bit set to zero specifies that the parameter list, if any, contains a short parameter list header as defined in table 39. 


1 A LONGLIST bit set to one specifies that the parameter list, if any, contains a long parameter list header as defined in table 40. 


FMTDATA (Format Data) 
0 A format data (FMTDATA) bit set to zero specifies that no parameter list be transferred from the data-out buffer. 


1 A FMTDATA bit set to one specifies that the FORMAT UNIT parameter list (see table 38) shall be transferred from the data-out buffer. The 
parameter list consists of a parameter list header, followed by an optional initialization pattern descriptor, followed by an optional defect 
list. 


CMPLST (Complete List) 
If the FMTDATA bit is set to zero, the CMPLIST bit shall be ignored. 


0 A complete list (CMPLST) bit set to zero specifies that the defect list included in the FORMAT UNIT parameter list shall be used in an addi- 
tion to the existing list of defects. As a result, the device server shall construct a new GLIST that contains: 


a) the existing GLIST; 
b) the DLIST, if it is sent by the application client; and 
c) the CLIST, if certification is enabled (i.e., the device server may add any defects it detects during the format operation). 


1 A CMPLST bit set to one specifies that the defect list included in the FORMAT UNIT parameter list is a complete list of defects. Any exist- 
ing GLIST shall be discarded by the device server. As a result, the device server shall construct a new GLIST that contains: 


a) the DLIST, if it is sent by the application client; and 
b) the CLIST, if certification is enabled (i.e., the device server may add any defects it detects during the format operation). 


DEFECT LIST FORMAT field 
The DEFECT LIST FORMAT field specifies the format of the address descriptors in the defect list if the FMTDATA bit is set to one (see table 36). 
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Table 36 defines the address descriptor usage for the FORMAT UNIT command. 


Table 36 


FORMAT UNIT command address descriptor usage (Sheet 1 of 2) 


Direct Access Block commands (SPC-5 and SBC-4) 





























































































































Field in the FORMAT UNIT CDB DEFECT LIST LENGTH field 
in the parameter list Type [a] Comments 1 
FMTDATA CMPLST Re soeneD header 
0 Any 000b Not available M Vendor-specific defect information 
0 O See !bl and [dl 
Zero 
[b] [e] 
; 1 AGob O See '™ and 
0 (short block) O See [4 and [1 
Nonzero 
1 oO See [¢l and lel 
0 O See !l and [al 
250 [b] . 4 fel 
e 
; 1 seas O See '™! and 
0 (long block) O See !¢l and I! 
Nonzero 
1 Oo See !¢l and lel 
0 O See !l and [al 
zet0 [b] 4 fel 
e 
1 an O See '™! and 
0 (long block) O See !¢l and I! 
Nonzero 
1 Oo See [¢l and lel 
0 O See |! and [al 
zet0 [b] , 4 [el 
e 
1 ane O See '™/ and 
0 (long block) Oo See [¢l and [41 
Nonzero 
1 oO See !¢l and le! 
0 O See |! and [al 
Zero 
1 100b O See ll and le! 
1 (bytes from 
0 inden O See [¢l and [41 
Nonzero 
1 oO See !¢l and Fel 





oF; 


aoe eee 
Qa 
o 


= 
3 





a] M=implementation is mandatory. O = implementation is optional. 
No DLIST is included in the parameter list. 

c] A DLISTis included in the parameter list. The device server shall add the DLIST defects to the new GLIST. 
The device server shall add existing GLIST defects to the new GLIST (i.e., use the existing GLIST). 

e] The device server shall not add existing GLIST defects to the new GLIST (i.e., discard the existing GLIST). 


All the options described in this table cause a new GLIST to be created during processing of the FORMAT UNIT 
command as described in the text. 
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Table 36 FORMAT UNIT command address descriptor usage (Sheet 2 of 2) 



























































Field in the FORMAT UNIT CDB DEFECT LIST LENGTH field 
: . [f] 
DEFECT LIST in the parameter list Type [a] Comments 
FMTDATA CMPLST FORMAT header 
0 O See !l and [al 
Zero 
1 101b O See [bl ang lel 
1 (physical 
0 sector) O See [¢l and [41 
Nonzero 
1 O See !¢l and le! 
0 110b O 
1 t= —__ (vendor Vendor specific 
1 specific) O 
All others Reserved. 
[al _M=implementation is mandatory. O = implementation is optional. 
[b] No DLIST is included in the parameter list. 
[c] ADLIST is included in the parameter list. The device server shall add the DLIST defects to the new GLIST. 
[d] The device server shall add existing GLIST defects to the new GLIST (i.e., use the existing GLIST). 
[e] The device server shall not add existing GLIST defects to the new GLIST (i.e., discard the existing GLIST). 
[f] All the options described in this table cause a new GLIST to be created during processing of the FORMAT UNIT 
command as described in the text. 
FFM field 


The fast format (FFMT) field is described in table 37. 


Table 37 FFM field description 





Code Description Support 





00b The device server initializes the medium as specified in the CDB and parameter list before complet- | Mandatory 
ing the format operation. After successful completion of the format operation, read commands and 
verify commands are processed as described in SBC-4. 


01b The device server initializes the medium without overwriting the medium (i.e., resources for man- Optional 
aging medium access are initialized and the medium is not written) before completing the format 
operation. After successful completion of the format operation, read commands and verify com- 
mands are processed as described in SBC-4. 


If the device server determines that the options specified in this FORMAT UNIT command are 
incompatible with the read command and verify command requirements described in SBC-4, then 
the device server shall not perform the format operation and shall terminate the FORMAT UNIT 
command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the addi- 
tional sense code set to INVALID FAST FORMAT COMBINATION. 


10b The device server initializes the medium without overwriting the medium (i.e., resources for man- Optional 
aging medium access are initialized and the medium is not written) before completing the format 
operation. After successful completion of the format operation, read commands and verify com- 
mands are processed as described in SBC-4. 


11b Reserved 

















CONTROL byte 
The CONTROL byte is defined in Clause 2.2.7. 
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3.3.2 FORMAT UNIT parameter list 


3.3.2.1 FORMAT UNIT parameter list overview 
Table 38 defines the FORMAT UNIT parameter list. 


Table 38 FORMAT UNIT parameter list 





Bit 7 6 5 4 3 2 1 0 
Byte 





Parameter List Header (see table 39 or table 40 in 3.3.3) 








Initialization Pattern Descriptor (if any) (see table 42, in 3.3.4) 








Defect List (if any) 














PARAMETER LIST HEADER field 
The PARAMETER LIST HEADER is defined in 3.3.3. 


INITIALIZATION PATTERN DESCRIPTOR field 
The INITIALIZATION PATTERN DESCRIPTOR, if any, is defined in 3.3.4. 


DEFECT LIST field 


The DEFECT LIST, if any, contains address descriptors (see table 36) each specifying a location on the medium that the device server shall 
exclude from the application client accessible part. This is called the DLIST. 
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3.3.3 


The parameter list headers (see table 39 and table 40) provide several optional format control parameters. Device servers that 
implement these headers provide the application client additional control over the use of the four defect sources, and the 
format operation. If the application client attempts to select any function not implemented by the device server, the device 
server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the 


Parameter list header 


additional sense code set to INVALID FIELD IN PARAMETER LIST. 


Direct Access Block commands (SPC-5 and SBC-4) 


The short parameter list header (see table 39) is used if the LONGLIST bit is set to zero in the FORMAT UNIT CDB. 






































Table 39 Short parameter list header 
Bit 7 6 5 4 3 2 1 0 
Byte 

0 Reserved PROTECTION FIELDS USAGE 

1 FOV DPRY DCRT STPF IP Obsolete IMMED wendet 
specific 

2 (MSB) 

DEFECT LIST LENGTH 
3 (LSB) 











The long parameter list header (see table 40) is used if the LONGLIST bit is set to one in the FORMAT UNIT CDB. 















































Table 40 Long parameter list header 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 Reserved PROTECTION FIELDS USAGE 
1 FOV DPRY DCRT STPF IP Obsolete IMMED oa 
2 Reserved 
3 P_I_LINFORMATION PROTECTION INTERVAL EXPONENT 
4 (MSB) 
DEFECT LIST LENGTH 
7 (LSB) 











The PROTECTION FIELD USAGE field in combination with the FMTPINFO field (see table 41) specifies the requested protection 


type (see SBC-4). 
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Table 41 FMTPINFO field and PROTECTION FIELDS USAGE field (Sheet 1 of 2) 
Device server Application client 
indication specification 
Description 
[al [b) | FMTP | PROTECTION 
SPTI™ | PROTECT™'’| INFO | FIELD USAGE 
The logical unit shall be formatted to type 0 protection [cl (see SBC-4) resulting in the 

een 0 00b 000b P_TYPE field '4] being set to 000b. 

xxxb 0 00b >000b Illegal fe! 

xxxb 0 O1b xxxb Illegal {f] 

xxxb 0 1xb xxxb Illegal (f] 

The logical unit shall be formatted to type 0 protection !*! (see SBC-4) resulting in the 

ae ! 00b 000b P_TYPE field '4] being set to 000b. 

xxxb 1 00b >000b Illegal le! 

xxxb 1 Ob xxxb Illegal (f] 

000b 

001b 1 The logical unit shall be formatted to type 1 protection 9] (see SBC-4) resulting in the 
011b 10b 000b P_TYPE field '4] being set to 000b. 

111b 

000b 

001b 

011b 1 10b >000b Illegal fe] 

111b 

000b 1 11b xxxb Illegal [fl 

000b 

001b 1 The logical unit shall be formatted to type 2 protection !9! (see SBC-4) resulting in the 
011b 11b 000b P_TYPE field 4 being set to 001b. 

111b 

001b [el 

010b 1 11b >000b Illegal 

011b [el 

100b 1 11b 000b Illegal 

011b 

100b 1 The logical unit shall be formatted to type 3 protection_9! (see SBC-4) resulting in the 
101b 11b 001b P_TYPE field '“! being set to 010b. 

111b 

011b 

100b [el 

101b 1 11b >001b Illegal 

111b 

110b 1 1xb xxxb Reserved 
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Table 41 FMTPINEFO field and PROTECTION FIELDS USAGE field (Sheet 2 of 2) 





Device server Application client 
indication specification 





SPT | PROTECT™'| iro | FIELD USAGE 


Description 
FMTP | PROTECTION 

















[a] 
[b] 
[c] 


[d] 
[el 


{f] 


[gl 





See the Extended INQUIRY Data VPD page (see 5.4.9) for the definition of the SPT field. 
See the standard INQUIRY data (see 3.6.2) for the definition of the PROTECT bit. 


The device server shall format the medium to the block length specified in the mode parameter block descriptor of the mode parameter header (see 
5.3.3). 


See the READ CAPACITY command (see 3.22.1) for the definition of the P_TYPE field. 

The device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense 
code set to INVALID FIELD IN PARAMETER LIST. 

The device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense 
code set to INVALID FIELD IN CDB. 

The device server shall format the medium to the block length specified in the mode parameter block descriptor of the mode parameter header plus 
eight (e.g., if the block length is 512, then the formatted block length is 520). Following a successful format, the PROT_EN bit in the READ CAPACITY (16) 
parameter data (see 3.23.2) indicates whether protection information (see SBC-4) is enabled. 





FOV (Format Options Valid) bit 


0 


A format options valid (FOV) bit set to zero specifies that the device server shall use its default settings for the DPRY, DCRT, STPF, and IP 
bits. If the FOV bit is set to zero, the application client shall set these bits to zero. If the FOV bit is set to zero and any of the other bits 
listed in this paragraph are not set to zero, the device server shall terminate the command with CHECK CONDITION status with the sense 
key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


A FOV bit set to one specifies that the device server shall examine the values of the DPRY, DCRT, STPF, and IP bits. When the FOV bit is set 
to one, the DPRY, DCRT, STPF, and IP bits are defined as follows. 


DPRY (Disable Primary) bit 


0 


A disable primary (DPRY) bit set to zero specifies that the device server shall not use parts of the medium identified as defective in the 
PLIST for application client accessible logical blocks. If the device server is not able to locate the PLIST or it is not able to determine 
whether a PLIST exists, it shall take the action specified by the STPF bit. 


A DPRY bit set to one specifies that the device server shall not use the PLIST to identify defective areas of the MEDIUM. The PLIST shall 
not be deleted. 


DCRT (disable certification) bit 


0 Adisable certification (DCRT) bit set to zero specifies that the device server shall perform a vendor-specific medium certification opera- 
tion to generate a CLIST. 
1 A DCRT bit set to one specifies that the device server shall not perform any vendor-specific medium certification process or format veri- 
fication operation. 
STPF (Stop Format) bit 


The stop format (STPF) bit controls the behavior of the device server if one of the following events occurs: 


a) The device server has been requested to use the PLIST (i.e., the DPRY bit is set to zero) or the GLIST (i-e., the CMPLST bit is set to zero) 
and the device server is not able to locate the list or determine whether the list exists; or 


b) The device server has been requested to use the PLIST (i.e., the DPRY bit is set to zero) or the GLIST (i-e., the CMPLST bit is set to zero), 
and the device server encounters an error while accessing the defect list. 


A STPF bit set to zero specifies that, if one or both of these events occurs, the device server shall continue to process the FORMAT UNIT 
command. The device server shall return CHECK CONDITION status at the completion of the FORMAT UNIT command with the sense key 
set to RECOVERED ERROR and the additional sense code set to either DEFECT LIST NOT FOUND if the condition described in item a) 
occurred, or DEFECT LIST ERROR if the condition described in item b) occurred. 


A STPF bit set to one specifies that, if one or both of these events occurs, the device server shall terminate the FORMAT UNIT command 
with CHECK CONDITION status and the sense key shall be set to MEDIUM ERROR with the additional sense code set to either DEFECT 
LIST NOT FOUND if the condition described in item a) occurred, or DEFECT LIST ERROR if the condition described in item b) occurred. 
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NOTE = _ The use of the FMTDATA bit, the CMPLST bit, and the parameter list header allow the application client 
to control the source of the defect lists used by the FORMAT UNIT command. Setting the DEFECT LIST 
LENGTH field to zero allows the application client to control the use of PLIST and CLIST without having 
to specify a DLIST. 


IP (initialization pattern) bit 


0 An initialization pattern (IP) bit set to zero specifies that an initialization pattern descriptor is not included and that the device server 
shall use its default initialization pattern. 


1 An IP bit set to one specifies that an initialization pattern descriptor (see 3.3.4) is included in the FORMAT UNIT parameter list following 
the parameter list header. 


IMMED (Immediate) bit 
0 An immediate (IMMED) bit set to zero specifies that the device server shall return status after the format operation has completed. 


1 An IMMED bit value set to one specifies that the device server shall return status after the entire parameter list has been transferred. 


P_I_INFORMATION field 
The P_l_INFORMATION field shall be set to zero. 


PROTECTION INTERVAL EXPONENT field 


For a type 1 protection information request, if the PROTECTION INTERVAL EXPONENT field is not set to zero, then the device 
server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the 
additional sense code set to INVALID FIELD IN PARAMETER LIST. 


For a type 2 protection or a type 3 protection format request, the protection interval exponent determines the length of user 
data to be sent before protection information is transferred (i.e., the protection information interval). 


The protection information interval is calculated as follows: 


Equation 1 protection information interval = logical block length / 2'Protection interval exponent) 
where: 


logical block length is the length in bytes of a logical block as specified in the mode parameter block descriptor (see clause 
5.3.4.1) 


protection interval exponent _ is the contents of the PROTECTION INTERVAL EXPONENT field 
If the protection information interval calculates to a value that is not an even number (e.g., 520/23 = 65) or not a whole number 


(e.g., 520/24 = 32.5 and 520/2!° = 0.508), then the device server shall terminate the command with CHECK CONDITION status 
with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


DEFECT LIST LENGTH field 
The DEFECT LIST LENGTH field specifies the total length in bytes of the defect list (ie., the address descriptors) that follows and does not 
include the initialization pattern descriptor, if any. The formats for the address descriptor(s) are shown in table 44. 


Address descriptors should be in ascending order. More than one physical or logical block may be affected by each address 
descriptor. If the address descriptors are not in the required order, the device server shall terminate the command with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN 
PARAMETER LIST. 
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3.3.4 Initialization pattern descriptor 


The initialization pattern descriptor specifies that the device server initialize logical blocks to a specified pattern. The 
initialization pattern descriptor (see table 42) is sent to the device server as part of the FORMAT UNIT parameter list. 












































Table 42 Initialization pattern descriptor 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 OBSOLETE SI Reserved 
1 INITIALIZATION PATTERN TYPE 
2 (MSB) 
INITIALIZATION PATTERN LENGTH (n - 3) a 
3 (LSB) 
4 
INITIALIZATION PATTERN 
n 














SI (Security Initialize) bit 


This bit is not supported on Seagate products. Customers should use the SANITIZE command to satisfy secure initialization requirements. 


INITIALIZATION PATTERN TYPE field 


The INITIALIZATION PATTERN TYPE field (see table 43) specifies the type of pattern the device server shall use to initialize each logical block 
within the application client accessible part of the medium. All bytes within a logical block shall be written with the initialization pattern. The 
initialization pattern is modified by the IP MODIFIER field as described in table 43. 


Table 43 INITIALIZATION PATTERN TYPE field 











Code Description 
00h Use a default initialization pattern [a] 
Oth Repeat the pattern specified in the INITIALIZATION PATTERN field as required to fill the logical block [b] 





02h - 7Fh Reserved 
80h - FFh Vendor-specific 








[a] If the INITIALIZATION PATTERN LENGTH field is not set to zero, the device server shall terminate the command with CHECK CONDI- 
TION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


{b] If the INITIALIZATION PATTERN LENGTH field is set to zero, the device server shall terminate the command with CHECK CONDITION 
status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 











INITIALIZATION PATTERN LENGTH field 


The INITIALIZATION PATTERN LENGTH field specifies the number of bytes contained in the INITIALIZATION PATTERN field. If the initialization 
pattern length exceeds the current block length the device server shall terminate the command with CHECK CONDITION status with the sense 
key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


INITIALIZATION PATTERN field 
The INITIALIZATION PATTERN field specifies the initialization pattern. 
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3.3.5 Address descriptor formats 


3.3.5.1 Address descriptor formats overview 


This subclause describes the address descriptor formats used in the FORMAT UNIT command, the READ DEFECT DATA 
commands (see 3.24 and 3.25), and the Translate Address diagnostic pages (see 5.1.3) of the SEND DIAGNOSTIC command and 
the RECEIVE DIAGNOSTIC RESULTS command. 


The format type of an address descriptor is specified with: 


a) the DEFECT LIST FORMAT field in the CDB, for the FORMAT UNIT command and the READ DEFECT DATA commands; 
b) the SUPPLIED FORMAT field, for the SEND DIAGNOSTIC command Translate Address diagnostic page; or 
c) the TRANSLATE FORMAT field, for the RECEIVE DIAGNOSTIC RESULTS command Translate Address diagnostic page. 


Table 44 defines the types of address descriptors. 


Table 44 Address descriptor formats 



































Formattype |Description Reference 

000b Short block format address descriptor 3.3.5.2 

001b Extended bytes from index address descriptor {al 3.3.5.3 

010b Extended physical sector address descriptor lal 3.3.5.4 

011b Long block format address descriptor 3.3.5.5 

100b Bytes from index format address descriptor 3.3.5.6 

101b Physical sector format address descriptor 3.3.5.7 

110b Vendor-specific 

All others Reserved 
| [a] This address descriptor format type is defined for direct access block devices sé 

using rotating media (see SBC-4). 





3.3.5.2 Short block format address descriptor 
A format type of 000b specifies the short block format address descriptor defined in table 45. 


Table 45 Short block format address descriptor (000b) 























Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
SHORT BLOCK ADDRESS 
3 (LSB) 
SHORT BLOCK ADDRESS field 


For the FORMAT UNIT command, the SHORT BLOCK ADDRESS field contains the four-byte LBA of a defect. For the READ DEFECT DATA com- 
mands, the SHORT BLOCK ADDRESS field contains a vendor-specific four-byte value. For the Translate Address diagnostic pages, the SHORT 
BLOCK ADDRESS field contains a four-byte LBA or a vendor-specific four byte value that is greater than the capacity of the medium. 
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3.3.5.3 Extended bytes from index address descriptor 


A format type of 001b specifies the extended bytes from index address descriptor defined in table 46. For the FORMAT UNIT 
command and the READ DEFECT DATA command, this descriptor specifies the location of a defect that is either: 

a) the length of one track; 

b) is less than the length of a physical block; or 

c) adefect that starts from one address descriptor and extends to the next address descriptor. 
For the Translate Address diagnostic pages, this descriptor specifies the location of an LBA. If format type 001b is used in the 
SUPPLIED FORMAT field of a Translate Address Output diagnostic page (see 5.1.4), and the MADS bit in the ADDRESS TO 


TRANSLATE field is set to one, then the device server shall terminate the SEND DIAGNOSTIC command with CHECK CONDITION 
status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


Table 46 Bytes from index format address descriptor (100b) 



























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

CYLINDER NUMBER 
2 (LSB) 
3 HEAD NUMBER 
4 MADS Reserved (MSB) 

BYTES FROM INDEX oa ail 

7 (LSB) 





CYLINDER NUMBER field 
The CYLINDER NUMBER field contains the cylinder number. 


HEAD NUMBER field 
The HEAD NUMBER field contains the head number. 


MADS bit 


A multi-address descriptor start (MADS) bit set to one specifies that this descriptor defines the beginning of a defect that spans multiple 
address descriptors. The defect may be a number of sequential physical blocks on the same cylinder and head (i.e., a track) or may be a number 
of sequential tracks on the same head. A MADS bit set to zero specifies that: 


a) this descriptor defines the end of a defect if the previous address descriptor has the MADS bit set to one; or 


b) this descriptor defines a single defective physical track (i.e., the BYTES FROM INDEX field contains FFF_FFFFh) or a single defective physical 
block (i.e., the BYTES FROM INDEX field does not contain FFF_FFFFh). 


See SBC-4 for valid combinations of two address descriptors that describe a defect. 


BYTES FROM INDEX field 
a) if not set to FFF_FFFFh, contains the number of bytes from the index (e.g., from the start of the track) to the location being described; or 
b) if set to FFF_FFFFh, specifies that the entire track is being described. 


For sorting bytes from index format address descriptors, the cylinder number is the most significant part of the address and the bytes from 
index is the least significant part of the address. More than one logical block may be described by this descriptor. 
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3.3.5.4 Extended physical sector address descriptor 


A format type of 010b specifies the extended physical sector address descriptor defined in table 47. For the FORMAT UNIT 
command and the READ DEFECT DATA commana, this descriptor specifies the location of a defect that is either: 


a) the length of one track; 
b) is less than the length of a physical block; or 
c) a defect that starts from one address descriptor and extends to the next address descriptor. 


For the Translate Address diagnostic pages, this descriptor specifies the location of an LBA. If format type 010b is used in the 
SUPPLIED FORMAT field of a Translate Address Output diagnostic page (see 5.1.4), and the MADS bit in the ADDRESS TO 
TRANSLATE field is set to one, then the device server shall terminate the SEND DIAGNOSTIC command with CHECK CONDITION 
status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


Table 47 Bytes from index format address descriptor (100b) 






























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
CYLINDER NUMBER 
2 (LSB) 
3 HEAD NUMBER 
4 MADS Reserved (MSB) 
SECTOR NUMBER ————— 
7 (LSB) 





CYLINDER NUMBER field 
The CYLINDER NUMBER field contains the cylinder number. 


HEAD NUMBER field 
The HEAD NUMBER field contains the head number. 


MADS bit 


A multi-address descriptor start (MADS) bit set to one specifies that this descriptor defines the beginning of a defect that spans multiple 
address descriptors. The defect may be a number of sequential physical blocks on the same cylinder and head (i.e., a track) or may be a number 
of sequential tracks on the same head. A MADS bit set to zero specifies that: 


a) this descriptor defines the end of a defect if the previous address descriptor has the MADS bit set to one; or 


b) this descriptor defines a single defective physical track (i.e., the BYTES FROM INDEX field contains FFF_FFFFh) or a single defective physical 
block (i.e., the BYTES FROM INDEX field does not contain FFF_FFFFh). 


See SBC-4 for valid combinations of two address descriptors that describe a defect. 


The SECTOR NUMBER field contains the sector number. A SECTOR NUMBER field set to FFF_FFFFh specifies that the entire track is 
being described. 


SECTOR NUMBER field 
a) if not set to FFF_FFFFh, contains the sector number of the location being described; or 
b) if set to FFF_FFFFh, specifies that the entire track is being described. 


For sorting extended physical sector address descriptors, the cylinder number is the most significant part of the address and the 
sector number is the least significant part of the address. More than one logical block may be described by this descriptor. 
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3.3.5.5 Long block format address descriptor 
A format type of 011b specifies the long block format address descriptor defined in table 48. 


Table 48 Long block format address descriptor (011b) 





























Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 





LONG BLOCK ADDRESS 














7 (LSB) 





LONG BLOCK ADDRESS field 


For the FORMAT UNIT command, the LONG BLOCK ADDRESS field contains the eight-byte logical block address of a defect. If multiple logical 
blocks are contained within a physical block, then the device server may consider logical blocks in addition to the one specified by this descrip- 
tor as containing defects. For the READ DEFECT DATA commands, the LONG BLOCK ADDRESS field contains a vendor-specific eight-byte value. 
For the Translate Address diagnostic pages, the LONG BLOCK ADDRESS field contains a four-byte LBA or a vendor-specific four byte value that 
is greater than the capacity of the medium. 


3.3.5.6 Bytes from index format address descriptor 


A format type of 100b specifies the bytes from index address descriptor defined in table 49. For the FORMAT UNIT command and 
the READ DEFECT DATA commands, this descriptor specifies the location of a defect that is either the length of one track or is no 
more than eight bytes long. For the Translate Address diagnostic pages, this descriptor specifies the location of a track or the first 
byte or last byte of an area. 


Table 49 Bytes from index format address descriptor (100b) 


























Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
CYLINDER NUMBER 
2 (LSB) 
3 HEAD NUMBER 
4 (MSB) 
BYTES FROM INDEX 
7 (SB) 











CYLINDER NUMBER field 
The CYLINDER NUMBER field contains the cylinder number. 


HEAD NUMBER field 
The HEAD NUMBER field contains the head number. 


BYTES FROM INDEX field 


The BYTES FROM INDEX field contains the number of bytes from the index (e.g., from the start of the track) to the location being described. A 
BYTES FROM INDEX field set to FFFFFFFFh specifies that the entire track is being described. 


For sorting bytes from index format address descriptors, the cylinder number is the most significant part of the address and the bytes from 
index is the least significant part of the address. More than one logical block may be described by this descriptor. 
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3.3.5.7 Physical sector format address descriptor 


A format type of 101b specifies the physical sector address descriptor defined in table 50. For the FORMAT UNIT command and the READ DEFECT 
DATA commands, this descriptor specifies the location of a defect that is either the length of one track or the length of one sector. For the 
Translate Address diagnostic pages, this descriptor specifies the location of a track or a sector. 


Table 50 Physical sector format address descriptor (101b) 












































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
CYLINDER NUMBER 
2 SB) 
3 HEAD NUMBER 
4 (MSB) 
SECTOR NUMBER 
7 (LSB) 














CYLINDER NUMBER field 
The CYLINDER NUMBER field contains the cylinder number. 


HEAD NUMBER field 
The HEAD NUMBER field contains the head number. 


SECTOR NUMBER field 


The SECTOR NUMBER field contains the sector number. A SECTOR NUMBER field set to FFFFFFFFh specifies that the entire track is being 
described. 


For sorting physical sector format address descriptors, the cylinder number is the most significant part of the address and the 
sector number is the least significant part of the address. More than one logical block may be described by this descriptor. 
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3.4 GET LBA STATUS command 


3.4.1 GET LBA STATUS command overview 


The GET LBA STATUS command (see table 51) requests that the device server transfer parameter data describing the logical 
block provisioning status (see SBC-4) for the specified LBA and zero or more subsequent LBAs to the Data-In Buffer. The device 
server may or may not process this command as an uninterrupted sequence of actions (e.g., if concurrent operations are 
occurring that affect the logical block provisioning status, then the returned parameter data may be inconsistent or out of date). 


This command uses the SERVICE ACTION IN (16) CDB format (see SBC-4 - Annex A.2). 


Table 51 GET LBA STATUS command 





















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (9Eh) 

1 Reserved SERVICE ACTION (12h) 

2 (MSB) 

3 STARTING LOGICAL BLOCK ADDRESS 

9 (LSB) 
10 (MSB) 
siete ALLOCATION LENGTH 

13 (LSB) 
14 Reserved 

15 CONTROL 








OPERATION CODE field 
The OPERATION CODE field is defined in SPC-5 and shall be set to the value shown in table 51 for the GET LBA STATUS command. 


SERVICE ACTION field 
The SERVICE ACTION field is defined in 2.2.2 and shall be set to the value shown in table 51 for the GET LBA STATUS command. 


STARTING LOGICAL BLOCK ADDRESS field 

The STARTING LOGICAL BLOCK ADDRESS field specifies the LBA of the first logical block addressed by this command. If the specified starting 
LBA exceeds the capacity of the medium (see SPC-5), then the device server shall terminate the command with CHECK CONDITION status with 
the sense key set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. 

ALLOCATION LENGTH field 


The ALLOCATION LENGTH field is defined in SPC-5. In response to a GET LBA STATUS command, the device server may send less data to the 
Data-In Buffer than is specified by the allocation length. If, in response to a single GET LBA STATUS command, the device server does not send 
sufficient data to the Data-In Buffer to satisfy the requirement of the application client, then, to retrieve additional information, the application 
client may send additional GET LBA STATUS commands with different starting LBA values. 

CONTROL byte 


The CONTROL byte is defined in Clause 2.2.7. 
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3.4.2 GET LBA STATUS parameter data 


3.4.2.1 GET LBA STATUS parameter data overview 


The GET LBA STATUS parameter data (see table 52) contains an eight-byte header followed by one or more LBA status 
descriptors. 


Table 52 GET LBA STATUS parameter data 












































Bit 7 6 5 4 3 2 1 0 
Byte 
0 
sae PARAMETER DATA LENGTH (n-3) 
3 
4 
secs Reserved 
7 
LBA status descriptors 
8 (MSB) 
LBA status descriptor [first] 
23 (LSB) 
n-15 (MSB) 
LBA status descriptor [last] 
n (LSB) 





PARAMETER DATA LENGTH field 


The PARAMETER DATA LENGTH field indicates the number of bytes of parameter data that follow. The value in the PARAMETER DATA LENGTH 
field shall be: 


a) at least 20 (i.e., the available parameter data shall contain at least one LBA status descriptor); and 
b) four added to a multiple of 16 (i.e., the available parameter data shall end on a boundary between LBA Status descriptors). 


Due to processing considerations outside the scope of this standard, two GET LBA STATUS commands with identical values in all CDB fields may 
result in two different values in the PARAMETER DATA LENGTH field. 


The relationship between the PARAMETER DATA LENGTH field and the ALLOCATION LENGTH field in the CDB is defined in SPC-5. 
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3.4.2.2 


LBA status descriptor 
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The LBA status descriptor (see table 53) contains LBA status information for one or more LBAs. 


Table 53 


LBA status descriptor format 





Bit 
Byte 


7 6 








5 




















0 


(MSB) 








LBA STATUS LOGICAL BLOCK ADDRESS 


(LSB) 





(MSB) 








11 


NUMBER OFLOGICAL BLOCKS 


(LSB) 





12 


Reserved 


PROVISIONING STATUS 





13 








15 














LBA STATUS LOGICAL BLOCK ADDRESS field 
The LBA STATUS LOGICAL BLOCK ADDRESS field contains the first LBA of the LBA extent for which this descriptor reports LBA status. 


NUMBER OF LOGICAL BLOCKS field 
The NUMBER OF LOGICAL BLOCKS field contains the number of logical blocks in that LBA extent. The device server should return the largest 


possible value in the NUMBER OF LOGICAL BLOCKS field. 


PROVISIONING STATUS field 


The PROVISIONING STATUS field is defined in table 54.. 


Table 54 


VERSION field codes 





Oh 
th 
2h 


Each LBA in the LBA extent is mapped (see SBC-4) or has an unknown state. 


Each LBA in the LBA extent is deallocated (see SBC-4). 


Each LBA in the LBA extent is anchored (see SBC-4). 


All others Reserved 





If the logical unit is fully provisioned (see SBC-4), then the PROVISIONING STATUS field for all LBAs shall be set to 0h (i.e., mapped or unknown). 


3.4.2.3 


LBA status descriptor relationships 


The LBA STATUS LOGICAL BLOCK ADDRESS field in the first LBA status descriptor returned in the GET LBA STATUS parameter data shall contain 
the value specified in the STARTING LOGICAL BLOCK ADDRESS field of the CDB. For subsequent LBA status descriptors, the contents of the LBA 


STATUS LOGICAL BLOCK ADDRESS field shall contain the sum of the values in: 


a) the LBA STATUS LOGICAL BLOCK ADDRESS field in the previous LBA status descriptor; and 


b) the NUMBER OF LOGICAL BLOCKS field in the previous LBA status descriptor. 


Adjacent LBA status descriptors may have the same values for the PROVISIONING STATUS field. 
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3.5 GET STREAM STATUS command 


The GET STREAM STATUS command (see table 55) requests that the device server transfer parameter data describing the status 
of streams (see SBC-4) for the logical unit to the Data-In Buffer. 


The device server may or may not process this command as an uninterrupted sequence of actions (e.g., if concurrent operations 
are occurring that affect the status of streams, then the returned parameter data may be inconsistent or out of date). 


Table 55 GET STREAM STATUS command 















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (9Eh) 

1 Reserved SERVICE ACTION (16h) 

2 

Reserved 

3 

4 

5 STARTING STREAM IDENTIFIER 

6 


Reserved 

















10 (MSB) 
ALLOCATION LENGTH 
13 (LSB) 
14 Reserved 
15 CONTROL 














The OPERATION CODE field and the SERVICE ACTION field shall be set to the values shown in table 55 for the GET STREAM STATUS command. 


OPERATION CODE field 

The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the value defined in 
table 55. 

SERVICE ACTION field 

The SERVICE ACTION field is defined in 2.2.2 and set to the value defined in table 55. 


STARTING STREAM IDENTIFIER field 


The STARTING STREAM IDENTIFIER field specifies the stream identifier of the first stream addressed by this command (see 3.5.1.2). If the speci- 
fied starting stream identifier exceeds the value indicated by the MAXIMUM NUMBER OF STREAMS field of the Block Limits VPD page (see 
5.4.5), then the device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the 
additional sense code set to ILLEGAL FIELD IN CDB. 


The ALLOCATION LENGTH field is defined in SPC-5. If, in response to a single GET STREAM STATUS command, the device server does not send 
sufficient data to the Data-In Buffer to satisfy the requirement of the application client, then the application client may send additional GET 
STREAM STATUS commands with different starting stream identifier values to retrieve additional information. 
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3.5.1 


GET STREAM STATUS parameter data 
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The GET STREAM STATUS parameter data (see table 56) contains an eight-byte header followed by zero or more stream status 
descriptors. 







































































Table 56 GET STREAM STATUS parameter data 
Bit 7 6 5 1 0 
Byte 
0 
Sask PARAMETER DATA LENGTH (n-7) 
3 
4 
5 
6 (MSB) 
NUMBER OF OPEN STREAMS 
7 (LSB) 
stream status descriptors 
8 (MSB) 
sats stream status descriptor [first] 
15 (LSB) 
n-7 (MSB) 
stream status descriptor [last] 
n (LSB) 














PARAMETER DATA LENGTH field 


The PARAMETER DATA LENGTH field shall contain the length in bytes of the stream list. The stream list length is the number of open streams in 


the logical unit multiplied by eight. The contents of the STREAM LIST LENGTH field are not altered based on the allocation length. 


Due to processing considerations outside the scope of this standard, two GET STREAM STATUS commands with identical values in all CDB fields 


may result in two different values in the PARAMETER DATA LENGTH field. 


The relationship between the PARAMETER DATA LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 


NUMBER OF OPEN STREAMS field 


The NUMBER OF OPEN STREAMS field indicates the number of streams that are currently open in the logical unit. 
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3.5.1.1 Stream status descriptor 


The stream status descriptor (see table 57) contains stream status information for one open stream. 


Table 57 Stream status descriptor format 



























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 
- Reserved 
2 MSB 
( STREAM IDENTIFIER 
3 (LSB) 
4 
Reserved 
7 








STREAM IDENTIFIER field 
The STREAM IDENTIFIER field contains the stream identifier of an open stream. 


3.5.1.2 Stream status descriptor relationships 
The STREAM IDENTIFIER field in the first stream status descriptor returned in the GET STREAM STATUS parameter data shall contain: 
a) the value specified in the STARTING STREAM IDENTIFIER field of the CDB if that stream is open; or 
b) the value of the next greater stream identifier of an open stream. 


If the value specified in the STARTING STREAM IDENTIFIER field of the CDB is greater than the highest stream identifier of an open stream, then 
the device server shall not return any stream status descriptors. For subsequent stream status descriptors, the contents of the STREAM IDENTI- 
FIER field shall contain the value of the next greater stream identifier of an open stream. 
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3.6 INQUIRY command 


3.6.1 INQUIRY command introduction 


The INQUIRY command (see table 58) requests that information regarding the logical unit and SCSI target device be sent to the 
application client. 


Table 58 INQUIRY command 












































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (12h) 
Obsolete 
1 Reserved Formerly EVPD 
CMDDT 
2 PAGE CODE 
3 (MSB) 
ALLOCATION LENGTH = 
4 (LSB) 
5 CONTROL 














EVPD (Enable Vital Product Data) bit 


An enable vital product data (EVPD) bit set to one specifies that the device server shall return the vital product data specified by 
the PAGE CODE field (see 3.6.3). 


0 If the EVPD bit is set to zero, the device server shall return the standard INQUIRY data (see 3.6.2). If the PAGE CODE field is not set to zero 
when the EVPD bit is set to zero, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

1 When the EVPD bit is set to one, the PAGE CODE field specifies which page of vital product data information the device server shall 
return (see 5.4). 


CMDDT (Command Support Data) bit 


This bit has been declared obsolete by the T10 committee. However, it is included because it may be implemented on some products.See 
SPC-2 for a description of this bit. 


If both the EVPD and CMDDT bits are one, the target shall return CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and an 
additional sense code of Invalid Field in CDB. When the EVPD bit is one, the Page or OPERATION CODE field specifies which page of vital prod- 
uct data information the target shall return. 
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ALLOCATION LENGTH field 
The ALLOCATION LENGTH field is defined in 2.2.6. If EVPD is set to zero, the allocation length should be at least five, so that the ADDITIONAL 


LENGTH field in the parameter data (see 3.6.2) is returned. If EVPD is set to one, the allocation length should be should be at least four, so that 
the PAGE LENGTH field in the parameter data (see 5.4) is returned. 


In response to an INQUIRY command received by an incorrect logical unit, the SCSI target device shall return the INQUIRY data 
with the peripheral qualifier set to the value defined in 3.6.2. The INQUIRY command shall return CHECK CONDITION status only 
when the device server is unable to return the requested INQUIRY data. 


If an INQUIRY command is received from an initiator port with a pending unit attention condition (i.e., before the device server 
reports CHECK CONDITION status), the device server shall perform the INQUIRY command and shall not clear the unit attention 
condition (see SAM-5). 


The INQUIRY data should be returned even though the device server is not ready for other commands. The standard INQUIRY 
data should be available without incurring any media access delays. If the device server does store some of the standard 
INQUIRY data or VPD data on the media, it may return ASCII spaces (20h) in ASCII fields and zeros in other fields until the data is 
available from the media. 


The INQUIRY data may change as the SCSI target device and its logical units perform their initialization sequence. (E.g., logical 
units may provide a minimum command set from nonvolatile memory until they load the final firmware from the media. After 
the firmware has been loaded, more options may be supported and therefore different INQUIRY data may be returned.) 


If the INQUIRY data changes for any reason, the device server shall establish a unit attention condition for the initiator port 
associated with every |_T nexus (see SAM-5), with the additional sense code set to INQUIRY DATA HAS CHANGED. 


The INQUIRY command may be used by an application client after a hard reset or power on condition to determine the device 
types for system configuration. 
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3.6.2 


Standard INQUIRY data 
The standard INQUIRY data (see table 59) shall contain at least 36 bytes 
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Table 59 Standard INQUIRY data format 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 
1 RMB Reserved 
2 VERSION 
3 Obsolete Obsolete NORMACA HISUP RESPONSE DATA FORMAT 
4 ADDITIONAL LENGTH (N-4) 
5 sccs ACC TPGS 3PC Reserved PROTECT 
6 Obsolete ENCSERV VS MULTIP Obsolete Obsolete Obsolete Obsolete 
7 Obsolete Obsolete Obsolete Obsolete Obsolete Obsolete CMDQUE VS 
8 (MSB) 
T10 VENDOR IDENTIFICATION 
15 (LSB) 
16 (MSB) 
PRODUCT IDENTIFICATION 
31 (LSB) 
32 (MSB) 
PRODUCT REVISION LEVEL 
35 (LSB) 
36 
DRIVE SERIAL NUMBER 
43 
44 
Vendor Unique 
Seagate fills this field with 00h. 
55 
56 Reserved Reserved Reserved Reserved 
57 Reserved 
58 (MSB) 
VERSION DESCRIPTOR 1 — | 
59 (LSB) 
72 (MSB) 
VERSION DESCRIPTOR 8 [ae af 
73 (LSB) 
74 
Reserved 
95 
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Table 59 Standard INQUIRY data format 












































Bit 7 6 5 4 3 2 1 0 
Byte 
Vendor specific parameters 
96 (MSB) 
Copyright Notice (Vendor specific) 
n (LSB) 








PERIPHERAL QUALIFIER and PERIPHERAL DEVICE TYPE fields 


The PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field identify the peripheral device connected to the logical unit. If the SCSI tar- 
get device is not capable of supporting a peripheral device connected to this logical unit, the device server shall set these fields to 7Fh (i.e., 
PERIPHERAL QUALIFIER field set to 011b and PERIPHERAL DEVICE TYPE field set to 1Fh). 


The peripheral qualifier is defined in table 60 and the peripheral device type is defined in table 61 


Table 60 PERIPHERAL QUALIFIER 














Qualifier Description 

A peripheral device having the specified peripheral device type is connected to this logical unit. If the device server is 

000b unable to determine whether or not a peripheral device is connected, it also shall use this peripheral qualifier. This 
peripheral qualifier does not mean that the peripheral device connected to the logical unit is ready for access. 

001b A peripheral device having the specified peripheral device type is not connected to this logical unit. However, the 
device server is capable of supporting the specified peripheral device type on this logical unit. 

010b Reserved 
The device server is not capable of supporting a peripheral device on this logical unit. For this peripheral qualifier the 

011b peripheral device type shall be set to 1Fh. All other peripheral device type values are reserved for this peripheral quali- 
fier. 

100b -111b Vendor specific 
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Table 61 PERIPHERAL DEVICE TYPE 




















Code Doc. [a] Description 
00h SBC-4 Direct access block device (e.g., magnetic disk) 

Oth SSC-3 Sequential-access device (e.g., magnetic tape) 

02h SSC Printer device 

03h SPC-2 Processor device 

04h SBC Write-once device (e.g., some optical disks) 

05h MMC-5 CD/DVD device 

06h Scanner device (obsolete) 

07h SBC Optical memory device (e.g., some optical disks) 
08h SMC-3 Medium changer device (e.g., jukeboxes) 

09h Communications device (obsolete) 

OAh - OBh Obsolete 

0Ch SCC-2 Storage array controller device (e.g., RAID) 

ODh SES Enclosure services device 

OEh RBC Simplified direct-access device (e.g., magnetic disk) 
OFh OCRW Optical card reader/writer device 

10h BCC Bridge Controller Commands 

11h OSD Object-based Storage Device 

12h ADC-2 Automation/Drive Interface 

13h-1Dh Reserved 
1Eh Well known logical unit [b] 
1Fh Unknown or no device type 
[a] All standards are subject to revision, and parties to agreements based on the standard are encouraged to 
investigate the possibility of applying the most recent editions of the listed standards. 
[b] All well known logical units use the same peripheral device type code. 








RMB (Removable Media) bit 


0 A removable medium (RMB) bit set to zero indicates that the medium is not removable. 


1 A RMB bit set to one indicates that the medium is removable. 


SCSI Commands Reference Manual, Rev. J 


96 


www.seagate.com Direct Access Block commands (SPC-5 and SBC-4) 


VERSION field 
The VERSION field indicates the implemented version of the SPC standard and is defined in table 62 . 


Table 62 VERSION field codes 














Code Description 
00h The device does not claim conformance to any standard. 
02h Obsolete 
03h The device complies to ANSI INCITS 301-1997 (SPC). 
04h The device complies to ANSI INCITS 351-2001 (SPC-2). 
05h The device complies to ANSI INCITS 408-2005 (SPC-3). 
06h The device complies to ANSI INCITS 513-2015 (SPC-4) 
07h The device complies to T10/BSR INCITS 503 (SPC-5) 
Code Description Code Description 
O1h Obsolete (SCSI=001b) 07h Reserved 
08h - 0Ch Obsolete (ECMA=001b) ODh - 3Fh Rekenidd 
40h - 44h Obsolete (ISO=01b) 45h -47h Reserved 
48h - 4Ch Obsolete (ISO=01b & ECMA=001b) ADh - 7Fh Reserved 
80h - 84h Obsolete (ISO=10b) 85h-87h Reserved 
88h -8Ch Obsolete (ECMA=001b) 8Dh - FFh Reseed 




















NORMACA (Normal ACA Supported 


1 The Normal ACA Supported (NORMACA) bit set to one indicates that the device server supports a NACA bit set to one in the CDB CON- 
TROL byte and supports the ACA task attribute (see 2.2.7). 


0 ANORMACA bit set to zero indicates that the device server does not support a NACA bit set to one and does not support the ACA task 
attribute. 


HISUP (Hierarchical Support) bit 


0 = A hierarchical support (HISUP) bit set to zero indicates the SCSI target device does not use the hierarchical addressing model to assign 
LUNs to logical units. 


1 A HISUP bit set to one indicates the SCSI target device uses the hierarchical addressing model to assign LUNs to logical units. 


RESPONSE DATA FORMAT field 


A RESPONSE DATA FORMAT field value of two indicates that the data shall be in the format defined in this manual. Response data format values 
less than two are obsolete. Response data format values greater than two are reserved. 


ADDITIONAL LENGTH field 
The ADDITIONAL LENGTH field indicates the length in bytes of the remaining standard INQUIRY data. The relationship between the ADDI- 
TIONAL LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 


SCCS (SCC Supported) bit 


1 An SCC Supported (SCCS) bit set to one indicates that the SCSI target device contains an embedded storage array controller component. 
See SCC-2 for details about storage array controller devices. 


0 AnSCCS bit set to zero indicates that the SCSI target device does not contain an embedded storage array controller component. 
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ACC (Access Controls Coordinator) bit 


1 An Access Controls Coordinator (ACC) bit set to one indicates that the SCSI target device contains an access controls coordinator that 
may be addressed through this logical unit. 


0 = ANnACC bit set to zero indicates that no access controls coordinator may be addressed through this logical unit. If the SCSI target device 
contains an access controls coordinator that may be addressed through any logical unit other than the ACCESS CONTROLS well known 
logical unit, then the ACC bit shall be set to one for LUN 0. 


TPGS (Target Port Group Support) field 


The contents of the target port group support (TPGS) field (see table 63) indicate the support for asymmetric logical unit access. 


Table 63 Target Port Group Support codes 





Code Description 





00b The SCSI target device does not support asymmetric logical unit access or supports a form of asymmetric access that 
is vendor specific. Neither the REPORT TARGET GROUPS nor the SET TARGET GROUPS commands is supported. 





Only implicit asymmetric logical unit access (see SPC-5) is supported. The SCSI target device is capable of changing 
01b target port asymmetric access states without a SET TARGET PORT GROUPS command. The REPORT TARGET PORT 
GROUPS command is supported and the SET TARGET PORT GROUPS command is not supported. 


Only explicit asymmetric logical unit access (i.e., the TPGS field contains 10b or 11b) is supported. The SCSI target 
10b device only changes target port asymmetric access states as requested with the SET TARGET PORT GROUPS com- 
mand. Both the REPORT TARGET PORT GROUPS command and the SET TARGET PORT GROUPS command are sup- 
ported. 


11b Both explicit and implicit asymmetric logical unit access are supported. Both the REPORT TARGET PORT GROUPS com- 
mand and the SET TARGET PORT GROUPS commands are supported. 














3PC (Third-Party Copy) bit 


1 A Third-Party Copy (3PC) bit set to one indicates that the SCSI target device supports third-party copy commands such as the EXTENDED 
COPY command. 


0 = A 3PC bit set to zero indicates that the SCSI target device does not support such commands. 


PROTECT bit 
0 =A PROTECT bit set to zero indicates that the logical unit does not support protection information (i.e. type 0) (see SPC-5 and SBC-4). 
1 A PROTECT bit set to one indicates that the logical unit supports type 1 protection, type 2 protection, or type 3 protection (see SBC-4). 
The SPT field in the Extended INQUIRY Data VPD page (see 5.4.9) indicates which type of protection the logical unit supports. 
ENCSERV (Enclosure Services) bit 


1 An Enclosure Services (ENCSERV) bit set to one indicates that the SCSI target device contains an embedded enclosure services compo- 
nent. See SES for details about enclosure services, including a device model for an embedded enclosure services device. 


O  AnENCSERYV bit set to zero indicates that the SCSI target device does not contain an embedded enclosure services component. 


MULTIP (Multi Port) bit 


1 A Multi Port (MULTIP) bit set to one indicates that this is a multi-port (two or more ports) SCSI target device and conforms to the SCSI 
multi-port device requirements found in the applicable standards (e.g., SAM-5, a SCSI transport protocol standard and possibly provi- 
sions of acommand standard). 


0 AMULTIP bit set to zero indicates that this SCSI target device has a single port and does not implement the multi-port requirements. 


CMDQUE (Command Queuing) bit 


If the logical unit does not support the BQUE bit, CMDQUE bit shall be set to one indicating that the logical unit supports the task management 
model (see SAM-5). 
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If the logical unit supports the BQUE bit, the CMDQUE bit and BQUE bit indicate whether the logical unit supports the full task management 
model as described in table 64. 


Table 64 BQue and CmdQue bit combinations 




















BQue CmdQue Description 
0 0 Obsolete 
0 1 Full task management model supported 
1 0 Basic task management model supported 
1 1 Illegal combination of BQUE and CMDQUE bits 





T10 VENDOR IDENTIFICATION field 


The T10 VENDOR IDENTIFICATION field contains eight bytes of left-aligned ASCII data (see 5.4.2) identifying the vendor of the product. The T10 
vendor identification shall be one assigned by INCITS. Bytes 8 through 15 contain the ASCII characters that represent “SEAGATE” (53h 45h 41h 
47h 41h 54h 45h 20h (space)). 


PRODUCT IDENTIFICATION 


The PRODUCT IDENTIFICATION field contains sixteen bytes of left-aligned ASCII data (see 5.4.2) defined by Seagate. Bytes 16 through 31 indi- 
cate the drive model with 20h (space) used as a filler. The table below is an example of drive test data returned by the drive. Bytes 16 and 17 will 
contain 53 54 for all drive models. 


Refer to the applicable Seagate product manual to get the actual text string. 


PRODUCT REVISION LEVEL field 


The PRODUCT REVISION LEVEL field contains four bytes of left-aligned ASCII data defined by Seagate. Bytes 32 through 35 contain the four 
ASCII digits representing the last four digits of the product Firmware Release number. 


VERSION DESCRIPTOR fields 


The VERSION DESCRIPTOR fields provide for identifying up to eight standards to which the SCSI target device claims conformance. The value in 
each VERSION DESCRIPTOR field shall be selected from the Version Descriptor Values Table in the current SPC standard. All version descriptor 
values not listed in table 62 are reserved. Technical Committee T10 of INCITS maintains an electronic copy of the information in the Version 
Descriptor Values Table on its world wide web site (http://www.t10.org/). In the event that the T10 world wide web site is no longer active, 
access may be possible via the INCITS world wide web site (http://www.incits.org), the ANSI world wide web site (http://www.ansi.org), the IEC 
site (http://www.iec.ch/), the ISO site (http://www.iso.ch/), or the ISO/IEC JTC 1 web site (http://www.iso.ch/). It is recommended that the first 
version descriptor be used for the SCSI architecture standard, followed by the physical transport standard if any, followed by the SCSI transport 
protocol standard, followed by the appropriate SPC version, followed by the device type command set, followed by a secondary command set 
if any. Refer to the latest SPC version for a complete list of descriptor values. 


Copyright Notice field 


Seagate uses bytes 96 - 143 to provide a copyright notice that begins “Copyright (c) XXXX Seagate All rights reserved,” where “XXXX” indicates 
the year the drive's firmware code was built (for example: 2016. 
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3.6.3 Vital product data 


The application client requests the vital product data information by setting the EVPD bit to one and specifying the page code of 
a vital product data. See 5.4 for details about vital product data. The information returned consists of configuration data (e.g., 
vendor identification, product identification, model, serial number), manufacturing data (e.g., plant and date of manufacture), 
field replaceable unit data and other vendor specific or device specific data. If the device server does not implement the 
requested page, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, 
and the additional sense code set to INVALID FIELD IN CDB. 


The device server should have the ability to process the INQUIRY command even when an error occurs that prohibits normal 
command completion. In such a case, CHECK CONDITION status should be returned for commands other than INQUIRY or 
REQUEST SENSE. The sense data returned may contain the field replaceable unit code. The vital product data may be obtained 
for the failing device using the INQUIRY command. 


This manual defines a format that allows device-independent application client software to display the vital product data 
returned by the INQUIRY command. The contents of the data may be vendor specific, and may be unusable without detailed 
information about the device. 


This manual does not define the location or method of storing the vital product data. The retrieval of the data may require 
completion of initialization operations within the device, that may induce delays before the data is available to the application 
client. Time-critical requirements are an implementation consideration and are not addressed in the standard. 
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3.7 LOG SELECT command 


The LOG SELECT command (see table 65) provides a means for an application client to manage statistical information 
maintained by the SCSI target device about the SCSI target device or its logical units. Device servers that implement the LOG 
SELECT command shall also implement the LOG SENSE command. Structures in the form of log parameters within log pages are 
defined as a way to manage the log data. The LOG SELECT command provides for sending zero or more log pages via the 
Data-Out Buffer. This manual defines the format of the log pages (see 5.2.2), but does not define the conditions and events that 
are logged. Application clients should issue LOG SENSE commands prior to issuing LOG SELECT commands to determine 
supported log pages and page lengths. 


Table 65 LOG SELECT command 















































Bit 7 6 5 4 3 2 1 oO 
Byte 
0 OPERATION CODE (4Ch) 
1 Reserved PCR SP 
2 PC PAGE CODE 
3 SUBPAGE CODE 
4 (MSB) 
Reserved 
6 (LSB) 
7 (MSB) 
PARAMETER LIST LENGTH 
8 (LSB) 
9 CONTROL 














PCR (Parameter Code Reset) bit 


The parameter code reset (PCR) bit instructs a device server whether or not to set parameters to their vendor specific default values (e.g., zero) as 
described in table 68. 


SP (Save Parameters) bit 


The save parameters (SP) bit instructs a device server whether or not to save parameters to non-volatile memory as described in 
table 68. 
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PC (Page Control) field 


The page control (PC) field specifies which data counter parameter values (i.e., when the FORMAT AND LINKING field (see 5.2.2) contains 00b or 
10b) shall be processed by a device server in response to a LOG SELECT command as described in table 66. The PC field shall be ignored for list 
parameters (i.e., when the FORMAT AND LINKING field contains 01b or 11b). 


Table 66 Page Control (PC) field values 








Values Description 
00b Threshold values 
01b Cumulative values 
10b Default threshold values 
11b Default cumulative values 














The threshold values and cumulative values for data counter parameters are: 


1) the current values if there has been an update to a cumulative parameter value (e.g., by a LOG SELECT command or by a device specific 
event) in the specified page or pages since the last logical unit reset occurred; 

2) the saved values, if saved parameters are implemented, current values have been saved, and an update has not occurred since the last 
logical unit reset; or 

3) the vendor specific default values, if saved values are not available or not implemented. 


When evaluated together, the combination of the values in the PCR bit, the SP bit, and the PC field specify the actions that a SCSI 
target device performs while processing a LOG SELECT command (see table 68). 


PARAMETER LIST LENGTH field 


If the PARAMETER LIST LENGTH field is set to zero, the PAGE CODE field and SUBPAGE CODE field specify the log page or log pages to which the 
other CDB fields apply (see 3.7.1). 


Since each log page in the parameter list contains a PAGE CODE field and SUBPAGE CODE field (see 5.2.2), the command shall be terminated 
with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB, if: 


a) the PARAMETER LIST LENGTH field contains a value other than zero, and: 
A) the PAGE CODE field contains a value other than zero; or 
B) the SUBPAGE CODE field contains a value other than zero. 


The PARAMETER LIST LENGTH field specifies the length in bytes of the parameter list that shall be located in the Data-Out Buffer. 


If the PARAMETER LIST LENGTH field contains zero, no log pages shall be transferred. This condition shall not be considered an error. The LOG 
SELECT command shall be processed as described in 3.7.1. 
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3.7.1 Processing LOG SELECT when the parameter list length is zero 


If the PARAMETER LIST LENGTH field is set to zero (i.e., when there is no parameter data being sent with a LOG SELECT command), the SCSI target 
device responds by processing the log parameter values as described in this subclause. 


PAGE CODE field and SUBPAGE CODE field 
The PAGE CODE field and SUBPAGE CODE field (see table 67) specify the log page or log pages to which the other CDB fields apply (see table 


67). 


Table 67 PAGE CODE field and SUBPAGE CODE field 

















PAGE CODE field| SUBPAGE CODE field Description 
00h 00h All log parameters in all log pages fal 
00h to 3Fh 01h to FEh All log parameters in the log page specified by the page code and subpage code 
00h to 3Fh FFh Alllog parameters in the log pages specified by page code and all subpage codes 
01h to 3Fh 00h All log parameters in the log page specified by the page code 
[a] This is equivalent to the LOG SELECT command operation specified by previous versions of this standard. 








Table 68 defines the meaning of the combinations of values for the PCR bit, the SP bit, and the PC field. 
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Table 68 PCR bit, SP bit, and PC field meanings when parameter list length is zero (Sheet 1 of 2) 





PCR | SP PC Description 
bit bit | field 


Ob Ob Oxb_ | This is not an error. The device server shall make no changes to any log parameter values and shall not 
save any values to non-volatile media. 








Ob 1b 00b_ | The device server shall make no changes to any log parameter values and shall process the optional 
saving of current parameter values as follows: 
a) ifthe values are current threshold data counter parameters, then: 
A)_ ifthe device server implements saving of the current threshold values, the device server shall 
save all current threshold values to non-volatile media; or 
B) if the device server does not implement saving of the current threshold values, the device 


server shall terminate the command. !#! 
or 
b) if the values are current list parameters, then: 
A)_ if the device server implements saving of the current list parameters, the device server shall 
save all current list parameters to non-volatile media; or 
B) if the device server does not implement saving of the current list parameters, the device 


server shall terminate the commana. !! 





Ob 1b 01b | The device server shall make no change to any log parameter values and shall process the optional 
saving of current parameter values as follows: 
a) ifthe values are current cumulative data counter parameters, then: 
A)_ if the device server implements saving of the current cumulative values, the device server 
shall save all current cumulative values to non-volatile media; or 
B) if the device server does not implement saving of the current cumulative values, the device 
server shall terminate the commana. !! 
or 
b) if the values are current list parameters, then: 
A)_ if the device server implements saving of the current list parameters, the device server shall 
save all current list parameters to non-volatile media; or 
B) if the device server does not implement saving of the current list parameters, the device 


server shall terminate the commana. !! 








Ob xb 10b_ | The device server shall set all current threshold values to the vendor specific default threshold 
values !5! and shall not save any values to non-volatile media. 

Ob xb 11b_ | The device server shall set all current cumulative values to the vendor specific default cumulative values 
[b] 


and shall not save any values to non-volatile media. 





1b Ob xxb_ | The device server shall: 


a) setall current threshold values to the vendor specific default threshold values; [b] 


b) set all current cumulative values to the vendor specific default cumulative values; {b] 


) set all list parameters to their vendor specific default values; and 

d) not save any values to non-volatile media. 

{al The command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, 
and the additional sense code set to INVALID FIELD IN CDB. 


[b] Vendor specific default threshold values and vendor specific default cumulative values may be zero. 


a 
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Table 68 PCR bit, SP bit, and PC field meanings when parameter list length is zero (Sheet 2 of 2) 








PCR | SP PC Description 
bit bit | field 
1b 1b 00b_ | The device server shall process the optional saving of current threshold values as follows: 


a) ifthe device server implements saving of the current threshold values, the device server shall: 
1) save all current threshold values to non-volatile media; 


2) set all current threshold values to the vendor specific default threshold values (b]. 


3) set all current cumulative values to the vendor specific default cumulative values [b] 
and 

4) set all list parameters to their vendor specific default values. 
or 


b) if the device server does not implement saving of the current threshold values, the device server 
shall terminate the command. ®! 





1b 1b 01b_ | The device server shall process the optional saving of current cumulative values as follows: 


a) ifthe device server implements saving of the current cumulative values, the device server shall: 
1) save all current cumulative values to non-volatile media; 


2) set all current threshold values to the vendor specific default threshold values (b]. 


3) set all current cumulative values to the vendor specific default cumulative values [b] 
and 

4) set all list parameters to their vendor specific default values. 
or 


b) if the device server does not implement saving of the current cumulative values, the device 
server shall terminate the command. ! 





1b 1b 1xb_ | The device server shall: 


a) setall current threshold values to the vendor specific default threshold values (b]. 


b) set all current cumulative values to the vendor specific default cumulative values [bl]. 


c) setall list parameters to their vendor specific default values; and 

d) not save any values to non-volatile media. 

{al The command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, 
and the additional sense code set to INVALID FIELD IN CDB. 


[b] Vendor specific default threshold values and vendor specific default cumulative values may be zero. 























The current cumulative values may be updated by the device server as defined for the specific log page or by the application 
client using the LOG SELECT command. The current threshold values may only be modified by the application client via the LOG 
SELECT command. 


NOTE Log pages or log parameters that are not available may become available at some later time (e.g., 
after the logical unit has become ready). 


Additional information about the LOG SELECT command is in Clause 3.7. 


The application client should send log pages in ascending order by page code value if the Data-Out Buffer contains multiple log 
pages. If the Data-Out Buffer contains multiple log parameters within a log page, then they should be sent in ascending order by 
parameter code value. If the application client sends log pages out of order or parameter codes out of order, the command shall 
be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
INVALID FIELD IN PARAMETER LIST. 
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3.8 


LOG SENSE command 


The LOG SENSE command (see table 69) provides a means for the application client to retrieve statistical or other operational 
information maintained by the SCSI target device about the SCSI target device or its logical units. It is a complementary 
command to the LOG SELECT command. See clause 4.2 of this manual for more information on returned log pages. 


Table 69 LOG SENSE command 



























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (4Dh) 
1 Reserved Obsolete SP 
2 PC PAGE CODE 
3 SUBPAGE CODE 
4 Reserved 
5 (MSB) 
PARAMETER POINTER 
6 (LSB) 
7 (MSB) 
ALLOCATION LENGTH 
8 (LSB) 
9 CONTROL 








SP (Saving Parameters) bit 


1 


0 


If saving log parameters is implemented, an SP bit set to one specifies that the device server shall perform the specified LOG SENSE com- 
mand and shall save all log parameters identified as saveable by the DS bit to a nonvolatile, vendor specific location. Saving parameters 
is an optional function of the LOG SENSE command. If the logical unit does not implement saving log parameters and if the save param- 
eters (SP) bit is set to one, then the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


An SP bit set to zero specifies the device server shall perform the specified LOG SENSE command and shall not save any log parameters. 


For data counter log parameters (i.e., when the FORMAT AND LINKING field in the parameter control byte in the log parameter 
structure (see 5.2.2.2) contains 00b or 10b), the page control (PC) table 66 specifies which log parameter values are to be 
returned by a device server in response to a LOG SENSE command. 


For list parameters (i.e., when the FORMAT ANDLINKING field in the parameter control byte in the log parameter structure (see 
5.2.2.2) contains 01b or 11b), the PC field shall be ignored. If the parameters specified by the PAGE CODE field and SUBPAGE 
CODE field in the CDB are list parameters, then the parameter values returned by a device server in response to a LOG SENSE 
command are determined as follows: 


the current list parameter values, if there has been an update to a list parameter value (e.g., by a LOG SELECT command or by a device 
specific event) in the specified page or pages since the last logical unit reset occurred; 

the saved list parameter values, if saved parameters are implemented and an update has not occurred since the last logical unit reset; or 
the vendor specific default list parameter values, if saved values are not available or not implemented and an update has not occurred 
since the last logical unit reset. 
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PAGE CODE and SUBPAGE CODE Fields 


The PAGE CODE field and SUBPAGE CODE field specify which log page of data is being requested. If the log page code and subpage combina- 
tion is reserved or not implemented, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


PARAMETER POINTER field 


The PARAMETER POINTER field allows the application client to request parameter data beginning from a specific parameter code to the maxi- 
mum allocation length or the maximum parameter code supported by the logical unit, whichever is less. If the value of the PARAMETER 
POINTER field is larger than the largest available parameter code known to the device server for the specified log page, the command shall be 
terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN 
CDB. 


ALLOCATION LENGTH field 
The ALLOCATION LENGTH field is defined in 2.2.6. 


Log parameters within the specified log page shall be transferred in ascending order according to parameter code. Additional information 
about the LOG SENSE command is in 5.2. 
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3.9 MODE SELECT(6) command 


The MODE SELECT(6) command (see table 70) provides a means for the application client to specify medium, logical unit, or 
peripheral device parameters to the device server. Device servers that implement the MODE SELECT(6) command shall also 
implement the MODE SENSE(6) command. Application clients should issue MODE SENSE(6) prior to each MODE SELECT(6) to 
determine supported mode pages, page lengths, and other parameters. 


Table 70 MODE SELECT(6) command 









































Bit 7 6 5 4 3 1 0 
Byte 
0 OPERATION CODE (15h) 
1 Reserved PF Reserved RTD SP 
2 
Reserved 
3 
4 PARAMETER LIST LENGTH 
5 CONTROL 














Logical units shall share mode parameter header and block descriptor values across all |_T nexuses. |_T nexus loss shall not affect 
mode parameter header, block descriptor, and mode page values. 


Logical units shall maintain current and saved values of each mode page based on any of the policies listed in table 71. The 
mode page policy used for each mode page may be reported in the Mode Page Policy VPD page (see 5.4.14). 


Table 71 Mode page policies 





Mode page policy Number of mode page copies 





Shared One copy of the mode page that is shared by all |_T nexuses. 





Per target port A separate copy of the mode page for each target port with each copy shared by all initiator ports. 














Per I_T nexus A separate copy of the mode page for each I_T nexus 





After a logical unit reset, each mode parameter header, block descriptor, and mode page shall revert to saved values if supported 
or default values if saved values are not supported. 


If an application client sends a MODE SELECT command that changes any parameters applying to other I_T nexuses, the device 
server shall establish a unit attention (see SAM-5) condition for the initiator port associated with every |_T nexus except the |_T 
nexus on which the MODE SELECT command was received, with the additional sense code set to MODE PARAMETERS CHANGED. 


PF (Page Format) bit 
0 = A page format (PF) bit set to zero specifies that all parameters after the block descriptors are vendor specific. 


1 A PF bit set to one specifies that the MODE SELECT parameters following the header and block descriptor(s) are structured as pages of 
related parameters and are as defined in this manual. If the RTD bit is set to one then the PF bit is ignored. 


RTD (revert to defaults) bit 


0 = AnRTD bit set to zero specifies that the device server shall process the MODE SELECT command based on the other fields in the CDB and 
parameter data. 


1 An RTD_SUP bit (see SPC-5) set to one and an RTD bit set to one specifies that the device server shall revert: 
a) current mode page values for all mode pages to their default values, if the SP bit is set to zero; and 
b) current mode page values and saved mode page values for all pages to their default values, if the SP bit is set to one. 
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SP (save pages) bit 

0 A save pages (SP) bit set to zero specifies that the device server shall perform the specified MODE SELECT operation, and shall not save 
any mode pages. If the logical unit implements no distinction between current and saved mode pages and the SP bit is set to zero, the 
command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense 
code set to INVALID FIELD IN CDB. An SP bit set to one specifies that the device server shall perform the specified MODE SELECT opera- 
tion, and shall save to a nonvolatile vendor specific location all the saveable mode pages including any sent in the Data-Out Buffer. 
Mode pages that are saved are specified by the parameter saveable (PS) bit that is returned in the first byte of each mode page by the 
MODE SENSE command. 


1 If the PS bit is set to one in the MODE SENSE data, then the mode page shall be saveable by issuing a MODE SELECT command with the 
SP bit set to one. If the logical unit does not implement saved mode pages and the SP bit is set to one, then the command shall be termi- 
nated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN 
CDB. 


PARAMETER LIST LENGTH field 


The PARAMETER LIST LENGTH field specifies the length in bytes of the mode parameter list that shall be contained in the Data-Out Buffer. A 
parameter list length of zero specifies that the Data-Out Buffer shall be empty. This condition shall not be considered as an error. 


If the parameter list length results in the truncation of any mode parameter header, mode parameter block descriptor(s), or mode page, then 
the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 
set to PARAMETER LIST LENGTH ERROR. 


The mode parameter list for the MODE SELECT and MODE SENSE commands is defined in 3.11. Parts of each mode parameter list are defined in 
a device-type dependent manner. Definitions for the parts of each mode parameter list that are unique for each device-type may be found in 
the applicable command standards. 


The device server shall terminate the MODE SELECT command with CHECK CONDITION status, set the sense key to ILLEGAL REQUEST, set the 
additional sense code to INVALID FIELD IN PARAMETER LIST, and shall not change any mode parameters in response to any of the following 
conditions: 


a) If the application client sets any field that is reported as not changeable by the device server to a value other than its current value; 
b) If the application client sets any field in the mode parameter header or block descriptor(s) to an unsupported value; 


c) If an application client sends a mode page with a page length not equal to the page length returned by the MODE SENSE command for 
that mode page; 


d) If the application client sends an unsupported value for a mode parameter and rounding is not implemented for that mode parameter; 
or 


e) If the application client sets any reserved field in the mode parameter list to a non-zero value and the device server checks reserved 
fields. 
If the application client sends a value for a mode parameter that is outside the range supported by the device server and rounding is imple- 
mented for that mode parameter, the device server handles the condition by either: 
a) Rounding the parameter to an acceptable value and terminating the command as described in 2.3; or 
b) Terminating the command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 
set to INVALID FIELD IN PARAMETER LIST. 


A device server may alter any mode parameter in any mode page, even those reported as non-changeable, as a result of changes to other 
mode parameters. 


The device server validates the non-changeable mode parameters against the current values that existed for those mode parameters prior to 
the MODE SELECT command. 


NOTE = The current values calculated by the device server may affect the application client's operation. The 
application client may issue a MODE SENSE command after each MODE SELECT command, to 
determine the current values. 
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The MODE SELECT(10) command (see table 72) provides a means for the application client to specify medium, logical unit, or 
peripheral device parameters to the device server. See the MODE SELECT(6) command (see 3.9) for a description of the fields and 
operation of this command. Application clients should issue MODE SENSE(10) prior to each MODE SELECT(10) to determine 
supported mode pages, page lengths, and other parameters. Device servers that implement the MODE SELECT(10) command 
shall also implement the MODE SENSE(10) command. 


















































Table 72 MODE SELECT(10) command 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (55h) 
1 Reserved PF Reserved SP 
2 
Reserved 

6 
7 (MSB) 

PARAMETER LIST LENGTH 
8 (LSB) 
9 CONTROL 
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3.11 MODE SENSE(6) command 


3.11.1 MODE SENSE(6) command introduction 


The MODE SENSE(6) command (see table 73) provides a means for a device server to report parameters to an application client. 
It is a complementary command to the MODE SELECT(6) command. Device servers that implement the MODE SENSE(6) 
command shall also implement the MODE SELECT(6) command. 


Table 73 MODE SENSE(6) command 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (1Ah) 

1 Reserved DBD Reserved 

2 PC PAGE CODE 

3 SUBPAGE CODE 

4 ALLOCATION LENGTH 

5 CONTROL 





DBD (disable block descriptors) bit 


0 A disable block descriptors (DBD) bit set to zero specifies that the device server may return zero or more block descriptors in the 
returned MODE SENSE data. 


1 A DBD bit set to one specifies that the device server shall not return any block descriptors in the returned MODE SENSE data. 


PC (Page Control) field 


The page control (PC) field specifies the type of mode parameter values to be returned in the mode pages. The PC field is defined in table 74. 


Table 74 Page control (PC) field 














Code Type of parameter Reference 
00b Current values 3.11.1.1 
01b Changeable values 3.11.1.2 
10b Default values 3.11.1.3 
11b Saved values 3.11.1.4 























The PC field only affects the mode parameters within the mode pages, however the PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and 


PAGE LENGTH field should return current values (i.e., as if PC is set to O0b). The mode parameter header and mode parameter block descriptor 
should return current values. 


Some SCSI target devices may not distinguish between current and saved mode parameters and report identical values in response to a PC 
field of either 00b or 11b. See also the description of the save pages (SP) bit in the MODE SELECT command. 


PAGE CODE and SUBPAGE CODE fields 
The PAGE CODE and SUBPAGE CODE fields specify which mode pages and subpages to return (see table 349). 


ALLOCATION LENGTH field 
The ALLOCATION LENGTH field is defined in 2.2.6. 
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An application client may request any one or all of the supported mode pages from the device server. If an application client 
issues a MODE SENSE command with a page code or subpage code value not implemented by the logical unit, the command 
shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 
set to INVALID FIELD IN CDB. 


If an application client requests all supported mode pages, the device server shall return the supported pages in ascending page 
code order beginning with mode page Oth. If mode page 00h is implemented, the device server shall return mode page 00h 
after all other mode pages have been returned. 


If the PC field and the PAGE CODE field are both set to zero, the device server should return a mode parameter header and block 
descriptor, if applicable. 


The mode parameter list for direct access devices for MODE SELECT and MODE SENSE is defined in 5.3. Parts of the mode 
parameter list are specifically defined for each device type. Definitions for the parts of each mode parameter list that are unique 
for each device-type may be found in the applicable command standards. 


3.11.1.1 Current values 


A PC field value of 00b requests that the device server return the current values of the mode parameters. The current values 
returned are: 


a) The current values of the mode parameters established by the last successful MODE SELECT command; 


b) The saved values of the mode parameters if a MODE SELECT command has not successfully completed since the mode 
parameters were restored to their saved values (see 3.7); or 


c) The default values of the mode parameters if a MODE SELECT command has not successfully completed since the mode 
parameters were restored to their default values (see 3.7). 


3.11.1.2. Changeable values 


A PC field value of 01b requests that the device server return a mask denoting those mode parameters that are changeable. In 
the mask, the bits in the fields of the mode parameters that are changeable all shall be set to one and the bits in the fields of the 
mode parameters that are non-changeable (i.e., defined by the logical unit) all shall be set to zero. 


If the logical unit does not implement changeable parameters mode pages and the device server receives a MODE SENSE 
command with 01b in the PC field, then the command shall be terminated with CHECK CONDITION status, with the sense key set 
to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


An attempt to change a non-changeable mode parameter using the MODE SELECT command shall result in an error condition 
(see 3.7). 


The application client should issue a MODE SENSE command with the PC field set to 01b and the PAGE CODE field set to 3Fh to 
determine which mode pages are supported, which mode parameters within the mode pages are changeable, and the 
supported length of each mode page prior to issuing any MODE SELECT commands. 
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3.11.1.3 Default values 


A PC field value of 10b requests that the device server return the default values of the mode parameters. Unsupported 
parameters shall be set to zero. Default values should be accessible even if the logical unit is not ready. 


3.11.1.4 Saved values 


A PC field value of 11b requests that the device server return the saved values of the mode parameters. Mode parameters not 
supported by the logical unit shall be set to zero. If saved values are not implemented, the command shall be terminated with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to SAVING 
PARAMETERS NOT SUPPORTED. 


The method of saving parameters is vendor specific. The parameters are preserved in such a manner that they are retained when 
the device is powered down. All saveable mode pages should be considered saved when a MODE SELECT command issued with 
the SP bit set to one has returned a GOOD status or after the successful completion of a FORMAT UNIT command. 


3.11.1.5 Initial responses 


After a logical unit reset, the device server shall respond in the following manner: 
a) If default values are requested, report the default values; 


b) If saved values are requested, report valid restored mode parameters, or restore the mode parameters and report them. If 
the saved values of the mode parameters are not able to be accessed from the nonvolatile vendor specific location, the 
command shall be terminated with CHECK CONDITION status, with the sense key set to NOT READY. If saved parameters 
are not implemented, respond as defined in 3.11.1.4; or 


c) _ If current values are requested and the current values have been sent by the application client via a MODE SELECT com- 
mand, the current values shall be returned. If the current values have not been sent, the device server shall return: 
a) The saved values, if saving is implemented and saved values are available; or 


b) The default values. 
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3.12 MODE SENSE(10) command 


The MODE SENSE(10) command (see table 75) provides a means for a device server to report parameters to an application client. 
It is a complementary command to the MODE SELECT(10) command. Device servers that implement the MODE SENSE(10) 
command shall also implement the MODE SELECT(10) command. 


Table 75 MODE SENSE(10) command 
























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (5Ah) 
1 Reserved LLBAA DBD Reserved 
2 PC PAGE CODE 
3 SUBPAGE CODE 
4 
Reserved 
6 
7 (MSB) ALLOCATION LENGTH 
8 (LSB) 
9 CONTROL 














LLBAA (Long LBA Accepted) bit 


1 If the Long LBA Accepted (LLBAA) bit is set to one, the device server is allowed to return parameter data with the LONGLBA bit equal to 
one. 


0 If LLBAA bit is set to zero, the LONGLBA bit shall be zero in the parameter data returned by the device server. 


See the MODE SENSE(6) command (3.11) for a description of the other fields and operation of this command. 
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3.13 PERSISTENT RESERVE IN command 


3.13.1 PERSISTENT RESERVE IN command introduction 


The PERSISTENT RESERVE IN command (see table 76) is used to obtain information about persistent reservations and reservation 
keys (i.e., registrations) that are active within a device server. This command is used in conjunction with the PERSISTENT RESERVE 
OUT command (see 3.14). 


Table 76 PERSISTENT RESERVE IN command 















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (5Eh) 
1 Reserved SERVICE ACTION 
2 

Reserved 
6 
7 (MSB) 

ALLOCATION LENGTH 

8 (LSB) 
9 CONTROL 











The service action codes for the PERSISTENT RESERVE IN command are defined in table 77. 


Table 77 PERSISTENT RESERVE IN service action codes 








Code Name Description Reference 
00h READ KEYS Reads all registered reservation keys (i.e., registrations) as described in SPC-5. 3.13.2 
01h READ RESERVATION Reads the current persistent reservations as described in SPC-5. 3.13.3 
02h REPORT CAPABILITIES | Returns capability information 3.13.4 
03h READ FULL STATUS ti complete information about all registrations and the persistent reservations, 3.13.5 

04h-1Fh | Reserved Reserved 
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3.13.2 READ KEYS service action 


The READ KEYS service action requests that the device server return a parameter list containing a header and a list of each currently registered 
|_T nexus’ reservation key. If multiple |_T nexuses have registered with the same key, then that key value shall be listed multiple times, once for 
each such registration. 


For more information on READ KEYS see SPC-5. 


The format for the parameter data provided in response to a PERSISTENT RESERVE IN command with the READ KEYS service 
action is shown in table 78. 


Table 78 PERSISTENT RESERVE IN parameter data for READ KEYS 



































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PRGENERATION 
3 (LSB) 
4 (MSB) 





ADDITIONAL LENGTH (N-7) 
7 (LSB) 








Reservation key list 























8 (MSB) 
Reservation key [first] 
15 (LSB) 
n-7 (MSB) 
Reservation key [last] 
n (LSB) 








PRGENERATION (Persistent Reservations Generation) field 


The Persistent Reservations Generation (PRGENERATION) field shall contain a 32-bit counter maintained by the device server that shall be incre- 
mented every time a PERSISTENT RESERVE OUT command requests a REGISTER service action, a REGISTER AND IGNORE EXISTING KEY service 
action, a REGISTER AND MOVE service action, a CLEAR service action, a PREEMPT service action, or a PREEMPT AND ABORT service action. The 
counter shall not be incremented by a PERSISTENT RESERVE IN command, by a PERSISTENT RESERVE OUT command that performs a RESERVE 
or RELEASE service action, or by a PERSISTENT RESERVE OUT command that is terminated due to an error or reservation conflict. Regardless of 
the APTPL bit value the PRGENERATION value shall be set to zero by a power on. 


ADDITIONAL LENGTH field 


The ADDITIONAL LENGTH field contains a count of the number of bytes in the Reservation key list. The relationship between the ADDITIONAL 
LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 


The reservation key list contains the 8-byte reservation keys for all |_T nexuses that have been registered (see SPC-5). 
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3.13.3 READ RESERVATION service action 


3.13.3.1 READ RESERVATION service action introduction 


The READ RESERVATION service action requests that the device server return a parameter list containing a header and the 
persistent reservation, if any, that is present in the device server. 


For more information on READ RESERVATION see SPC-5. 


3.13.3.2 PERSISTENT RESERVE IN parameter data for READ RESERVATION 


When no persistent reservation is held, the format for the parameter data provided in response to a PERSISTENT RESERVE IN 
command with the READ RESERVATION service action is shown in table 79. 


Table 79 PERSISTENT RESERVE IN data for READ RESERVATION with no reservation held 




















Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PRGENERATION 
3 (LSB) 
4 (MSB) 
ADDITIONAL LENGTH (0000_0000h) 
7 (LSB) 














PRGENERATION field 


The PRGENERATION field shall be as defined for the PERSISTENT RESERVE IN command with READ KEYS service action parameter data (see 
3.13.2). 


ADDITIONAL LENGTH field 
The ADDITIONAL LENGTH field shall be set to zero, indicating that no persistent reservation is held. 
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When a persistent reservation is held, the format for the parameter data provided in response to a PERSISTENT RESERVE IN 
command with the READ RESERVATION service action is shown in table 80. 


Table 80 PERSISTENT RESERVE IN parameter data for READ RESERVATION with reservation 














Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PRGENERATION 
3 (LSB) 
4 (MSB) 





ADDITIONAL LENGTH (0000-0010h) 
7 (LSB) 








8 (MSB) 





RESERVATION KEY 
15 (LSB) 








16 





Obsolete 


19 
20 Reserved 





21 SCOPE TYPE 








22 





Obsolete 





23 











PRGENERATION field 
The PRGENERATION field shall be as defined for the PERSISTENT RESERVE IN command with READ KEYS service action parameter data. 


ADDITIONAL LENGTH field 


The ADDITIONAL LENGTH field contains a count of the number of bytes to follow and shall be set to 16. The relationship between the ADDI- 
TIONAL LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 


RESERVATION KEY field 
The RESERVATION KEY field shall contain the reservation key under which the persistent reservation is held (see SPC-5). 


SCOPE field 
The scope field shall be set to LU_SCOPE (see 3.13.3.3). 


TYPE field 
The TYPE field shall contain the persistent reservation type (see 3.13.3.4) specified in the PERSISTENT RESERVE OUT command that created the 
persistent reservation. 


The obsolete fields in bytes 16 through 19, byte 22, and byte 23 were defined in a previous standard. 
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3.13.3.3 


The SCOPE field (see table 81) shall be set to LU_SCOPE, specifying that the persistent reservation applies to the entire logical 
unit. 


Persistent reservations scope 








Table 81 Persistent reservation scope codes 
Code Name Description 
Oh LU_SCOPE Persistent reservation applies to the full logical unit 
1h-2h Obsolete 
3h-Fh Reserved 

















The LU_SCOPE scope shall be implemented by all device servers that implement PERSISTENT RESERVE OUT. 


3.13.3.4 


The TYPE field (see table 82) specifies the characteristics of the persistent reservation being established for all logical blocks 
within the logical unit. SPC-5 defines the persistent reservation types under which each command defined in that standard is 
allowed to be processed. Each other command standard (e.g., SBC-4, SSC-3, SMC-3, MMC-5, or SES-3) defines the persistent 
reservation types under which each command defined in that command standard is allowed to be processed. 


Persistent reservations type 
































Table 82 Persistent reservation type codes 
Code Name Description 
Oh Obsolete 
Write Access Restrictions: Some commands (e.g., media-access write commands) are only 
th Exclusive allowed for the persistent reservation holder (see SPC-5). 
Persistent Reservation Holder: There is only one persistent reservation holder. 
2h Obsolete 
Exclusive Access Restrictions: Some commands (e.g., media-access commands) are only allowed for 
3h Access the persistent reservation holder (see SPC-5). 
Persistent Reservation Holder: There is only one persistent reservation holder. 
4h Obsolete 
Write Exclusive - Access Restrictions: Some commands (e.g., media-access write commands) are only 
5h Registrants allowed for registered |_T nexuses. 
Only Persistent Reservation Holder: There is only one persistent reservation holder (see SPC-5). 
Exclusive Access— | Access Restrictions: Some commands (e.g., media-access commands) are only allowed for 
6h Registrants registered |_T nexuses. 
Only Persistent Reservation Holder: There is only one persistent reservation holder (see SPC-5). 
Write Exclusive — Access Restrictions: Some commands (e.g., media-access write commands) are only 
yh All allowed for registered |_T nexuses. 
Registrants Persistent Reservation Holder: Each registered |_T nexus is a persistent reservation holder 
(see SPC-5). 
Exclusive Access— | Access Restrictions: Some commands (e.g., media-access commands) are only allowed for 
8h All registered |_T nexuses. 
Registrants Persistent Reservation Holder: Each registered |_T nexus is a persistent reservation holder 
(see SPC-5). 
9h- Fh Reserved 
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3.13.4 
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REPORT CAPABILITIES service action 


The REPORT CAPABILITIES service action requests that the device server return information on persistent reservation features. 


The format for the parameter data provided in response to a PERSISTENT RESERVE IN command with the REPORT CAPABILITIES 
service action is shown in table 83. 




































































Table 83 PERSISTENT RESERVE IN parameter data for REPORT CAPABILITIES 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
LENGTH (0008h) 
1 (LSB) 
2 RLR_C Reserved CRH SIP_C ATP_C Reserved PTPL_C 
3 TMV ALLOW COMMANDS Reserved PTPL_A 
4 
; PERSISTENT RESERVATION TYPE MASK 
6 
Reserved 
7 
LENGTH field 


The LENGTH field indicates the length in bytes of the parameter data. The relationship between the LENGTH field and the CDB ALLOCATION 
LENGTH field is defined in 2.2.6. 


RLR_C (Replace Lost Reservation Capable) bit 


1 
0 


Indicates that the device server supports the REPLACE LOST RESERVATION service action in the PERSISTENT RESERVE OUT command. 


Indicates that the device server does not support the REPLACE LOST RESERVATION service action in the PERSISTENT RESERVE OUT com- 
mand. If set to 0 then the device server shall not terminate any commands with CHECK CONDITION status with the sense key set to DATA 
PROTECT and the additional sense code set to PERSISTENT RESERVATION INFORMATION LOST as described in SPC-5. 


CRH (Compatible Reservation Handling) field 


1 


0 


A Compatible Reservation Handling (CRH) bit set to one indicates that the device server supports the exceptions to the RESERVE and 
RELEASE commands described in SPC-5. 


A CRH bit set to zero indicates that RESERVE(6) command, RESERVE(10) command, RELEASE(6) command, and RELEASE(10) command 
are processed as defined in SPC-5. 


SIP_C (Specify Initiator Ports Capable) bit 


1 


0 


A Specify Initiator Ports Capable (SIP_C) bit set to one indicates that the device server supports the SPEC_I_PT bit in the PERSISTENT 
RESERVE OUT command parameter data (see 3.14.3). 


An SIP_C bit set to zero indicates that the device server does not support the SPEC_I_PT bit in the PERSISTENT RESERVE OUT command 
parameter data. 


ATP_C (Target Ports Capable) bit 


1 


0 
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PTPL_C (Persist Through Power Loss Capable) bit 


1 A Persist Through Power Loss Capable (PTPL_C) bit set to one indicates that the device server supports the persist through power loss 
capability see SPC-5 for persistent reservations and the APTPL bit in the PERSISTENT RESERVE OUT command parameter data. 


O  AnPTPL_C bit set to zero indicates that the device server does not support the persist through power loss capability. 


TMV (Type Mask Valid) bit 


1 A Type Mask Valid (TMV) bit set to one indicates that the PERSISTENT RESERVATION TYPE MASK field contains a bit map indicating which 
persistent reservation types are supported by the device server. 


0 ATMVbit set to zero indicates that the PERSISTENT RESERVATION TYPE MASK field shall be ignored. 


The ALLOW COMMANDS (see table 84) indicates whether certain commands are allowed through certain types of persistent reservations. 


Table 84 ALLOW COMMANDS field 











Code Description 

000b No information is provided about whether certain commands are allowed through certain types of persistent 
reservations. 

001b The device server allows the TEST UNIT READY command (see 3.53) through Write Exclusive and Exclusive 


Access persistent reservations and does not provide information about whether the following commands are 
allowed through Write Exclusive persistent reservations: 

a) the MODE SENSE, READ ATTRIBUTE, READ BUFFER, RECEIVE DIAGNOSTIC RESULTS, REPORT SUPPORTED 
OPERATION CODES, and REPORT SUPPORTED TASK MANAGEMENT FUNCTION commands (see 3.35); 
and 

b) the READ DEFECT DATA command (see 3.25). 

010b The device server allows the TEST UNIT READY command through Write Exclusive and Exclusive Access 
persistent reservations and does not allow the following commands through Write Exclusive persistent 
reservations: 

a) the MODE SENSE, READ ATTRIBUTE, READ BUFFER, RECEIVE DIAGNOSTIC RESULTS, REPORT SUPPORTED 
OPERATION CODES, and REPORT SUPPORTED TASK MANAGEMENT FUNCTION commands; and 

b) the READ DEFECT DATA command. 

The device server does not allow the RECEIVE COPY RESULTS command through Write Exclusive or Exclusive 
Access persistent reservations. 








011b The device server allows the TEST UNIT READY command through Write Exclusive and Exclusive Access 
persistent reservations and allows the following commands through Write Exclusive persistent reservations: 
a) the MODE SENSE, READ ATTRIBUTE, READ BUFFER, RECEIVE DIAGNOSTIC RESULTS, REPORT SUPPORTED 
OPERATION CODES, and REPORT SUPPORTED TASK MANAGEMENT FUNCTION commands; and 
b) the READ DEFECT DATA command. 
The device server does not allow the RECEIVE COPY RESULTS command through Write Exclusive or Exclusive 
Access persistent reservations. 


100b The device server allows the TEST UNIT READY command and the RECEIVE COPY RESULTS command through 
Write Exclusive and Exclusive Access persistent reservations and allows the following commands through Write 
Exclusive persistent reservations: 
a) the MODE SENSE command, READ ATTRIBUTE command, READ BUFFER command, RECEIVE 
DIAGNOSTIC RESULTS command, REPORT SUPPORTED OPERATION CODES command, and 
REPORT SUPPORTED TASK MANAGEMENT FUNCTION command; and 


b) the READ DEFECT DATA command. 
101bto111b_ | Reserved 

















PTPL_A (Persist Through Power Loss Activated) bit 


1 A Persist Through Power Loss Activated (PTPL_A) bit set to one indicates that the persist through power loss capability is activated (see 
SPC-5). 


0 = APTPL_A bit set to zero indicates that the persist through power loss capability is not activated. 
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PERSISTENT RESERVATION TYPE MASK field 
The PERSISTENT RESERVATION TYPE MASK field (see table 85) contains a bit map that indicates the persistent reservation types 


that are supported by the device server. 


Direct Access Block commands (SPC-5 and SBC-4) 





























Table 85 Persistent Reservation Type Mask format 
Bit 7 6 5 4 3 2 1 0 
Byte 
4 WR_EX_AR EX_AC_RO WR_EX_RO Reserved EX_AC Reserved WR_EX Reserved 
5 Reserved EX_AC_AR 














WR_EX_AR (Write Exclusive - All Registrants) bit 


1 


0 


A Write Exclusive - All Registrants (WR_EX_AR) bit set to one indicates that the device server supports the Write Exclusive — All Regis- 
trants persistent reservation type. 


An WR_EX_AR bit set to zero indicates that the device server does not support the Write Exclusive — All Registrants persistent reservation 
type. 


EX_AC_RO (Exclusive Access — Registrants Only) bit 


1 


0 


An Exclusive Access — Registrants Only (EX_AC_RO) bit set to one indicates that the device server supports the Exclusive Access — Regis- 
trants Only persistent reservation type. 


An EX_AC_RO bit set to zero indicates that the device server does not support the Exclusive Access — Registrants Only persistent reserva- 
tion type. 


WR_EX_RO (Write Exclusive - Registrants Only) bit 


1 


0 


A Write Exclusive - Registrants Only (WR_EX_RO) bit set to one indicates that the device server supports the Write Exclusive - Regis- 
trants Only persistent reservation type. 


An WR_EX_RO bit set to zero indicates that the device server does not support the Write Exclusive — Registrants Only persistent reserva- 
tion type. 


EX_AC (Exclusive Access) bit 


1 
0 


An Exclusive Access (EX_AC) bit set to one indicates that the device server supports the Exclusive Access persistent reservation type. 


An EX_AC bit set to zero indicates that the device server does not support the Exclusive Access persistent reservation type. 


WR_EX (Write Exclusive) bit 


1 
0 


A Write Exclusive (WR_EX) bit set to one indicates that the device server supports the Write Exclusive persistent reservation type. 


An WR_EX bit set to zero indicates that the device server does not support the Write Exclusive persistent reservation type. 


EX_AC_AR (Exclusive Access - All Registrants) 


1 


0 


An Exclusive Access — All Registrants (EX_AC_AR) bit set to one indicates that the device server supports the Exclusive Access — All Regis- 
trants persistent reservation type. 


An EX_AC_AR bit set to zero indicates that the device server does not support the Exclusive Access — All Registrants persistent reserva- 
tion type. 
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3.13.5 READ FULL STATUS service action 


The READ FULL STATUS service action requests that the device server return a parameter list describing the registration and 
persistent reservation status of each currently registered |_T nexus for the logical unit. 


For more information on READ FULL STATUS see SPC-5. 


The format for the parameter data provided in response to a PERSISTENT RESERVE IN command with the READ FULL STATUS 
service action is shown in table 86. 


Table 86 PERSISTENT RESERVE IN parameter data for READ FULL STATUS 






































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
oie PRGENERATION 
3 ss) | 
4 (MSB) 





a ADDITIONAL LENGTH (N-7) 
7 (LSB) 
Full status descriptors 














Full status descriptor [first] (see table 87) 








Full status descriptor [last] (see table 87) 
n 














PRGENERATION field 

The PRGENERATION field shall be as defined for the PERSISTENT RESERVE IN command with READ KEYS service action parameter data (see 
3.13.2). 

ADDITIONAL LENGTH field 


The ADDITIONAL LENGTH field contains a count of the number of bytes to follow in the full status descriptors. The relationship between the 
ADDITIONAL LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 
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The format of the full status descriptors is shown in table 87. Each full status descriptor describes one or more registered |_T 
nexuses. The device server shall return persistent reservations status information for every registered |_T nexus. 


Table 87 PERSISTENT RESERVE IN full status descriptor format 





Bit 7 6 5 4 3 2 1 0 
Byte 


0 (MSB) 





seis RESERVATION KEY 
7 (LSB) 








Reserved 





11 
12 Reserved ALL_TG_PT | R_HOLDER 
13 SCOPE TYPE 

14 

















Reserved 





17 

18 (MSB) 

—_—_ RELATIVE TARGET PORT IDENTIFIER —— 
19 (LSB) 


20 (MSB) 











Sore ADDITIONAL DESCRIPTOR LENGTH (N-23) 
23 (LSB) 
24 








TRANSPORTID 

















RESERVATION KEY field 
The RESERVATION KEY field contains the reservation key. 


R_HOLDER (Reservation Holder) bit 


1 A Reservation Holder (R_HOLDER) bit set to one indicates that all |_T nexuses described by this full status descriptor are registered and 
are persistent reservation holders. 


O AR_HOLDER bit set to zero indicates that all |_T nexuses described by this full status descriptor are registered but are not persistent res- 
ervation holders. 
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ALL_TG_PT (All Target Ports) bit 
0 An All Target Ports (ALL_TG_PT) bit set to zero indicates that this full status descriptor represents a single |_T nexus. 
1 An ALL_TG_PT bit set to one indicates that: 
a) This full status descriptor represents all the |_T nexuses that are associated with both: 
1. The initiator port specified by the TRANSPORTID field; and 
2. Every target port in the SCSI target device; 
b) All the |_T nexuses are registered with the same reservation key; and 
c) Allthe l_T nexuses are either reservation holders or not reservation holders as indicated by the R_-HOLDER bit. 


The device server is not required to return an ALL_TG_PT bit set to one. Instead, it may return separate full status descriptors for 
each |_T nexus. 


R_HOLDER bit 


1 If the RLHOLDER bit is set to one (i.e., if the |_T nexus described by this full status descriptor is a reservation holder), the scope field and 
the TYPE field are as defined in the READ RESERVATION service action parameter data (see 3.13.3). 


0 If the RLHOLDER bit is set to zero, the contents of the scope field and the TYPE field are not defined by this manual. 


ALL_TG_PT bit 


0 If the ALL_TG_PT bit set to zero, the RELATIVE TARGET PORT IDENTIFIER field contains the relative port identifier (see SPC-5) of the target 
port that is part of the I_T nexus described by this full status descriptor. 


1 If the ALL_TG_PT bit is set to one, the contents of the RELATIVE TARGET PORT IDENTIFIER field are not defined by this manual. 


ADDITIONAL DESCRIPTOR LENGTH field 

The ADDITIONAL DESCRIPTOR LENGTH field contains a count of the number of bytes that follow in the descriptor (i.e., the size of the TRANS- 
PORTID). 

TRANSPORTID field 


The TRANSPORTID field contains a TRANSPORTID (see SPC-5) identifying the initiator port that is part of the |_T nexus or |_T nexuses described 
by this full status descriptor. 
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3.14 PERSISTENT RESERVE OUT command 


3.14.1 PERSISTENT RESERVE OUT command introduction 


The PERSISTENT RESERVE OUT command (see table 88) is used to request service actions that reserve a logical unit for the 
exclusive or shared use of a particular |_T nexus. The command uses other service actions to manage and remove such persistent 
reservations. 


|_T nexuses performing PERSISTENT RESERVE OUT service actions are identified by a registered reservation key provided by the 
application client. An application client may use the PERSISTENT RESERVE IN command to obtain the reservation key, if any, for 
the I_T nexus holding a persistent reservation and may use the PERSISTENT RESERVE OUT command to preempt that persistent 
reservation. 


Table 88 PERSISTENT RESERVE OUT command 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (5Fh) 
1 Reserved SERVICE ACTION 
2 SCOPE TYPE 
3 

Reserved 
4 
5 (MSB) 

PARAMETER LIST LENGTH 

8 (LSB) 
9 CONTROL 














If a PERSISTENT RESERVE OUT command is attempted, but there are insufficient device server resources to complete the 
operation, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and 
the additional sense code set to INSUFFICIENT REGISTRATION RESOURCES. 


The PERSISTENT RESERVE OUT command contains fields that specify a persistent reservation service action, the intended scope 
of the persistent reservation, and the restrictions caused by the persistent reservation. The TYPE and SCOPE fields are defined in 
3.13.3.4 and 3.13.3.3. If a SCOPE field specifies a scope that is not implemented, the command shall be terminated with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


Fields contained in the PERSISTENT RESERVE OUT parameter list specify the information required to perform a particular 
persistent reservation service action. 


PARAMETER LIST LENGTH field 

The PARAMETER LIST LENGTH field specifies the number of bytes of parameter data for the PERSISTENT RESERVE OUT command. 

The parameter list shall be 24 bytes in length and the PARAMETER LIST LENGTH field shall contain 24 (18h), if the following conditions are true: 
a) The SPEC_I_PT bit (see 3.14.3) is set to zero; and 
b) The service action is not REGISTER AND MOVE. 


If the SPEC_I_PT bit is set to zero, the service action is not REGISTER AND MOVE, and the parameter list length is not 24, then the command 
shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to PARAME- 
TER LIST LENGTH ERROR. 


If the parameter list length is larger than the device server is able to process, the command should be terminated with CHECK CONDITION sta- 
tus, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to PARAMETER LIST LENGTH ERROR. 
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3.14.2 PERSISTENT RESERVE OUT service actions 


When processing the PERSISTENT RESERVE OUT service actions, the device server shall increment the PRGENERATION value as 
specified in 3.13.2. 


The PERSISTENT RESERVE OUT command service actions are defined in table 89. 
































Table 89 PERSISTENT RESERVE OUT service action codes 
PRGENERATION Parameter list 
Code Name Description field incremented 
format 
(see 3.13.2) 
REGISTER Register a reservation key with the device Yes Basic 
00h server (see SPC-5) or unregister a reservation (see 3.14.3) 
key (see SPC-5). 
RESERVE Creates a persistent reservation having a speci- No Basic 
Oth fied SCOPE and TYPE (see SPC-5). The SCOPE (see 3.14.3) 
and TYPE of a persistent reservation are defined 
in 3.13.3.3 and 3.13.3.4. 
RELEASE Releases the selected persistent reservation No Basic 
02h 
(see SPC-5). (see 3.14.3) 
h CLEAR Clears all reservation keys (i.e., registrations) Yes Basic 
03 and all persistent reservations (see SPC-5). (see 3.14.3) 
04h PREEMPT Preempts persistent reservations and/or Yes Basic 
4 removes registrations (see SPC-5). (see 3.14.3) 
PREEMPT AND Preempts persistent reservations and/or Yes Basic 
05h ABORT removes registrations and aborts all tasks for all (see 3.14.3) 
preempted I_T nexuses (see SPC-5) 
REGISTER AND Register a reservation key with the device Yes Basic 
06h IGNORE EXISTING server (see SPC-5) or unregister a reservation (see 3.14.3) 
KEY key (see SPC-5). 
REGISTER AND Register a reservation key for another |_T nexus Yes Register and 
07h MOVE with the device server and move a persistent move 
reservation to that |_T nexus (see SPC-5) (see 3.14.4) 
osh REPLACE LOST Replace lost persistent reservation information Yes Basic 
RESERVATION (see SPC-5) (see 3.14.3) 
09h - 1Fh Reserved 
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3.14.3 Basic PERSISTENT RESERVE OUT parameter list 


The parameter list format shown in table 90 shall be used by the PERSISTENT RESERVE OUT command with any service action 
except the REGISTER AND MOVE service action. All fields shall be sent, even if the field is not required for the specified service 
action and scope values. 


Table 90 PERSISTENT RESERVE OUT parameter list 

























































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
; RESERVATION KEY 
7 (LSB) 
8 (MSB) 
bse SERVICE ACTION RESERVATION KEY 
15 (LSB) 
16 
sae Obsolete 
19 
20 Reserved SPEC_|_PT ALL_TG_PT Reserved APTPL 
21 Reserved 
22 
a Obsolete 
24 
Additional parameter data 
n 











The obsolete fields in bytes 16 through 19, byte 22 and byte 23 were defined in a previous standard. 


RESERVATION KEY field 


The RESERVATION KEY field contains an 8-byte value provided by the application client to the device server to identify the |_T nexus that is the 
source of the PERSISTENT RESERVE OUT command. The device server shall verify that the contents of the RESERVATION KEY field in a PER- 
SISTENT RESERVE OUT command parameter data matches the registered reservation key for the |_T nexus from which the command was 
received, except for: 

a) The REGISTER AND IGNORE EXISTING KEY service action where the RESERVATION KEY field shall be ignored; and 

b) The REGISTER service action for an unregistered |_T nexus where the RESERVATION KEY field shall contain zero; and 

c) The REPLACE LOST RESERVATION service action where the RESERVATION KEY field shall contain zero. 
Except as noted above, when a PERSISTENT RESERVE OUT command specifies a RESERVATION KEY field other than the reservation key registered 


for the I_T nexus the device server shall return a RESERVATION CONFLICT status. Except as noted above, the reservation key of the I_T nexus 
shall be verified to be correct regardless of the SERVICE ACTION and SCOPE field values. 
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SERVICE ACTION RESERVATION KEY field 


The SERVICE ACTION RESERVATION KEY field contains information needed for the following service actions: REGISTER, REGISTER AND IGNORE 
EXISTING KEY, PREEMPT, PREEMPT AND ABORT, and REPLACE LOST RESERVATION. The SERVICE ACTION RESERVATION KEY field is ignored for the fol- 
lowing service actions: RESERVE, RELEASE, and CLEAR. 


For the REGISTER service action and REGISTER AND IGNORE EXISTING KEY service action, the SERVICE ACTION RESERVATION KEY field contains: 
a) The newreservation key to be registered in place of the registered reservation key specified in the RESERVATION KEY field; or 
b) Zero to unregister the registered reservation key specified in the RESERVATION KEY field. 

For the PREEMPT service action and PREEMPT AND ABORT service action, the SERVICE ACTION RESERVATION KEY field contains the reservation key of: 
a) The registrations to be removed; and 


b) If the SERVICE ACTION RESERVATION key field identifies a persistent reservation holder (see SPC-5), persistent reservations that are to be 
preempted. 


For the REPLACE LOST RESERVATION service action, the SERVICE ACTION RESERVATION KEY field contains the new reservation key to be regis- 
tered. 


SPEC_I_PT (Specify Initiator Ports) bit 


0 If the Specify Initiator Ports (SPEC_I_PT) bit is set to zero, the device server shall apply the registration only to the |_T nexus that sent the 
PERSISTENT RESERVE OUT command. 


1 If the SPEC_I_PT bit is set to one for the REGISTER service action or the REGISTER AND IGNORE EXISTING KEY service action, then the 
additional parameter data shall include a list of transport IDs (see table 91) and the device server shall also apply the registration to the 
|_T nexus for each initiator port specified by a TRANSPORTID. If a registration fails for any initiator port (e.g., if the logical unit does not 
have enough resources available to hold the registration information), no registrations shall be made, and the command shall be termi- 
nated with CHECK CONDITION status. 


Table 91 PERSISTENT RESERVE OUT specify initiator ports additional parameter data 





Bit 7 6 5 4 3 2 1 0 
Byte 


24 


























TRANSPORTID PARAMETER DATA LENGTH (N - 27) 

















27 
TransportIDs List 
28 
TransportID [first] 
TransportlID [last] 
n 
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TRANSPORTID PARAMETER DATA LENGTH field 
The TRANSPORTID PARAMETER DATA LENGTH field specifies the number of bytes of TRANSPORTIDs that follow. 
The command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST: 


a) If the value in the parameter list length field in the CDB does not include all of the additional parameter list bytes specified 
by the TRANSPORTID PARAMETER DATA LENGTH field; or 


b) — If the value in the TRANSPORTID PARAMETER DATA LENGTH field results in the truncation of a TRANSPORTID. 
The format of aTRANSPORTID is specified in SPC-5. 


ALL_TG_PT (All Target Ports) bit 


The All Target Ports (ALL_TG_PT) bit is valid only for the REGISTER service action and the REGISTER AND IGNORE EXISTING KEY service action, 
and shall be ignored for all other service actions. Support for the ALL_TG_PT bit is optional. 


1 If the device server receives a REGISTER service action or a REGISTER AND IGNORE EXISTING KEY service action with the ALL_TG_PT bit 
set to one, it shall create the specified registration on all target ports in the SCSI target device known to the device server (i.e., as if the 
same registration request had been received individually through each target port). 


0 If the device server receives a REGISTER service action or a REGISTER AND IGNORE EXISTING KEY service action with the ALL_TG_PT bit 
set to zero, it shall apply the registration only to the target port through which the PERSISTENT RESERVE OUT command was received. 


APTPL (Activate Persist Through Power Loss) bit 


1 The Activate Persist Through Power Loss (APTPL) bit is valid only for the REGISTER service action and the REGISTER AND IGNORE EXIST- 
ING KEY service action, and shall be ignored for all other service actions. Support for an APTPL bit equal to one is optional. If a device 
server that does not support an APTPL bit set to one receives that value in a REGISTER service action or a REGISTER AND IGNORE EXIST- 
ING KEY service action, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, 
and the additional sense code set to INVALID FIELD IN PARAMETER LIST. If the last valid APTPL bit value received by the device server is 
one, the logical unit shall retain any persistent reservation(s) that may be present and all reservation keys (i.e., registrations) for all |_T 
nexuses even if power is lost and later returned (see SPC-5). 


O If the last valid APTPL bit value received by the device server is zero, the loss of power in the SCSI target device shall release the per- 
sistent reservation for the logical unit and remove all registered reservation keys (see SPC-5). 
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Table 92 summarizes which fields are set by the application client and interpreted by the device server for each service action 
and scope value. 


















































Table 92 PERSISTENT RESERVE OUT service actions and valid parameters (part 1 of 2) 
Parameters (part 1 of 2) 
Service action Allowed SCOPE e. RESERVATION SERVICE ACTION an 
KEY RESERVATION KEY 
REGISTER ignored ignored valid valid valid 
REGISTER AND ignored ignored ignored valid valid 
IGNORE EXISTING 
KEY 
RESERVE LU_SCOPE valid valid ignored ignored 
RELEASE LU_SCOPE valid valid ignored ignored 
CLEAR ignored ignored valid ignored ignored 
PREEMPT LU_SCOPE valid valid valid ignored 
PREEMPT AND LU_SCOPE valid valid valid ignored 
ABORT 
REGISTER AND LU_SCOPE valid valid valid not 
MOVE applicable [a] 
REPLACE LOST LU_SCOPE valid valid valid valid 
RESERVATION 
[a] The parameter list format for the REGISTER AND MOVE service action is described in 3.14.4. 
























































Table 93 PERSISTENT RESERVE OUT service actions and valid parameters (part 2 of 2) 
Parameters (part 2 of 2) 
Service action Allowed SCOPE 
ALL_TG PT SPEC_I_PT 
REGISTER ignored valid valid 
REGISTER AND IGNORE ignored valid invalid 
EXISTING KEY 
RESERVE LU_SCOPE ignored invalid 
RELEASE LU_SCOPE ignored invalid 
CLEAR ignored ignored invalid 
PREEMPT LU_SCOPE ignored invalid 
PREEMPT AND ABORT LU_SCOPE ignored invalid 
REGISTER AND MOVE LU_SCOPE Not invalid 
applicable [a] 
REPLACE LOST LU_SCOPE invalid invalid 
RESERVATION 
[a] The parameter list format for the REGISTER AND MOVE service action is described in 3.14.4. 
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3.14.4 Parameter list for the PERSISTENT RESERVE OUT command with REGISTER AND MOVE 
service 


The parameter list format shown in table 94 shall be used by the PERSISTENT RESERVE OUT command with REGISTER AND MOVE 
service action. 


Table 94 PERSISTENT RESERVE OUT command with REGISTER AND MOVE service 





























Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 





RESERVATION KEY 
7 (LSB) 





8 (MSB) 





SERVICE ACTION RESERVATION KEY 


























15 (LSB) 
16 Reserved 
17 Reserved UNREG APTPL 
18 (MSB) 

RELATIVE TARGET PORT IDENTIFIER 
19 (LSB) 
20 (MSB) 





TRANSPORTID PARAMETER DATA LENGTH (N - 23) 
23 (LSB) 





24 
TRANSPORTID 

















RESERVATION KEY field 


The RESERVATION KEY field contains an 8-byte value provided by the application client to the device server to identify the |_T nexus that is the 
source of the PERSISTENT RESERVE OUT command. The device server shall verify that the contents of the RESERVATION KEY field in a PER- 
SISTENT RESERVE OUT command parameter data matches the registered reservation key for the |_T nexus from which the command was 
received. If a PERSISTENT RESERVE OUT command specifies a RESERVATION KEY field other than the reservation key registered for the |_T 
nexus, the device server shall return a RESERVATION CONFLICT status. 


SERVICE ACTION RESERVATION KEY field 
The SERVICE ACTION RESERVATION KEY field contains the reservation key to be registered to the specified |_T nexus. 
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APTPL (Activate Persist Through Power Loss) bit 


1 The Activate Persist Through Power Loss (APTPL) bit set to one is optional. If a device server that does not support an APTPL bit set to 
one receives that value, it shall return CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense 
code set to INVALID FIELD IN PARAMETER LIST. If the last valid APTPL bit value received by the device server is one, the logical unit shall 
retain any persistent reservation(s) that may be present and all reservation keys (i.e., registrations) for all |_T nexuses even if power is lost 
and later returned (see SPC-5). 


0 If the last valid APTPL bit value received by the device server is zero, the loss of power in the SCSI target device shall release the per- 
sistent reservation for the logical unit and remove all registered reservation keys (see SPC-5). 


UNREG (Unregister) bit 


0 The unregister (UNREG) bit set to zero specifies that the device server shall not unregister the |_T nexus on which the PERSISTENT 
RESERVE OUT command REGISTER AND MOVE service action was received. 


1 An UNREG bit set to one specifies that the device server shall unregister the |_T nexus on which the PERSISTENT RESERVE OUT command 
REGISTER AND MOVE service action was received. 
RELATIVE TARGET PORT IDENTIFIER field 
The RELATIVE TARGET PORT IDENTIFIER field specifies the relative port identifier of the target port in the |_T nexus to which the persistent res- 
ervation is to be moved. 
TRANSPORTID DESCRIPTOR LENGTH field 
The TRANSPORTID DESCRIPTOR LENGTH field specifies the number of bytes of the TRANSPORTID that follows, shall be a minimum of 24 bytes, 
and shall be a multiple of 4. 
TRANSPORTID field 


The TRANSPORTID field specifies the initiator port in the |_T nexus to which the persistent reservation is to be moved. The format of the Trans- 
portID is defined in SPC-5. 


The command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST: 


a) If the value in the PARAMETER LIST LENGTH field in the CDB does not include all of the parameter list bytes specified by the TRANSPOR- 
TID PARAMETER DATA LENGTH field; or 


b) If the value in the TRANSPORTID PARAMETER DATA LENGTH field results in the truncation of a TransportID. 
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3.15 READ (6) command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


The READ (6) command (see table 95) requests that the device server read the specified logical block(s) and transfer them to the 
data-in buffer. Each logical block read includes user data and, if the medium is formatted with protection information enabled, 
protection information. Each logical block transferred includes user data but does not include protection information. The most 
recent data value written, or to be written if cached, in the addressed logical blocks shall be returned. 


Table 95 READ (6) command 






































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (08h) 

1 Reserved (MSB) 

2 

LOGICAL BLOCK ADDRESS 

3 (LSB) 

4 TRANSFER LENGTH 

5 CONTROL 














The cache control bits are not provided for this command. Direct-access block devices with cache may have values for the cache control bits 
that affect the READ (6) command; however, no default values are defined by this manual. If explicit control is required, the READ (10) com- 
mand should be used. 


LOGICAL BLOCK ADDRESS field 


The LOGICAL BLOCK ADDRESS field specifies the first logical block accessed by this command. If the logical block address exceeds the capacity 
of the medium the device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. 


TRANSFER LENGTH field 


The TRANSFER LENGTH field specifies the number of contiguous logical blocks of data that shall be read and transferred to the data-in buffer, 
starting with the logical block specified by the LOGICAL BLOCK ADDRESS field. A TRANSFER LENGTH field set to zero specifies that 256 logical 
blocks shall be read. Any other value specifies the number of logical blocks that shall be read. If the logical block address plus the transfer 
length exceeds the capacity of the medium, the device server shall terminate the command with CHECK CONDITION status with the sense key 
set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. The TRANSFER LENGTH field is con- 
strained by the MAXIMUM TRANSFER LENGTH field in the Block Limits VPD page. 


a) Forthe READ (10) command, READ (12) command, READ (16) command, and READ (32) command, a TRANSFER LENGTH field set to zero 
specifies that no logical blocks are read. 


b) Although the READ (6) command is limited to addressing logical blocks up to a capacity of 2 Gigabytes, for block lengths of 512 bytes, 
this command has been maintained since some system initialization routines require that the READ (6) command be used. System ini- 
tialization routines should migrate from the READ (6) command to the READ (10) command, which is capable of addressing 2 Terabytes 
with block lengths of 512 bytes, or the READ (16) command to address more than 2 Terabytes. 
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The device server shall check the protection information read from the medium before returning status for the command as 
described in table 96. 
































Table 96 Protection information checking for READ (6) 
Logical unit . 
sormerediwittal eos de vice server | Field in protection ecendee RY If check fails [b] !<! 
rotection transmit protection informational Data VPD page bit dditional d 
P : information? value [d] additional sense code 
information 
Yes No LOGICAL BLOCK GRD_CHK=1 LOGICAL BLOCK GUARD CHECK FAILED 
GUARD 
GRD_CHK=0 No check performed 
LOGICAL BLOCK APP CHK=1/@1 | LOGICAL BLOCK APPLICATION TAG 
APPLICATION TAG = CHECK FAILED 
APP_CHK=0 No check performed 
LOGICAL BLOCK REF-| REF CHK =1[fllgl | LOGICAL BLOCK REFERENCE TAG CHECK 
ERENCE TAG : FAILED 
REF_CHK=0 No check performed 
No No protection information available to check 











[a] The device server checks the logical block application tag only if it has knowledge of the contents of the LOGICAL BLOCK 
APPLICATION TAG field. The method for acquiring this knowledge is not defined by this manual. 
[b] If an error is reported, the sense key shall be set to ABORTED COMMAND. 
[c] If multiple errors occur, the selection of which error to report is not defined by this manual. 
[d] See the Extended INQUIRY Data VPD page (see 5.4.9) for the definitions of the GRD_CHK bit, APP_CHK bit, 
and REF_CHK bit. 
[e] If the device server detects a: 
a) LOGICAL BLOCK APPLICATION TAG field set to FFFFh and type 1 protection (see SBC-4) 
or type 2 protection (see SBC-4) is enabled; 
or 
b) LOGICAL BLOCK APPLICATION TAG field set to FFFFh, LOGICAL BLOCK REFERENCE TAG 
field set to FFFF FFFFh, and type 3 protection (see SBC-4) is enabled, 


then the device server shall not check any protection information in the associated logical block. 


[f] If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to the lower 4 bytes 
of the LBA associated with the logical block. 


[g] If type 2 protection or type 3 protection is enabled, the device server checks the logical block reference tag only if it has 
knowledge of the contents of the LOGICAL BLOCK REFERENCE TAG field. The method for acquiring this knowledge is not 
defined by this manual. 
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3.16 


READ (10) command 


Direct Access Block commands (SPC-5 and SBC-4) 


The READ (10) command (see table 97) requests that the device server read the specified logical block(s) and transfer them to 
the data-in buffer. Each logical block read includes user data and, if the medium is formatted with protection information 
enabled, protection information. Each logical block transferred includes user data and may include protection information, 
based on the RDPROTECT field and the medium format. The most recent data value written in the addressed logical block shall 
be returned. 

































































Table 97 READ (10) command 
Bit 7 6 4 3 2 1 0 
Byte 
0 OPERATION CODE (28h) 
1 RDPROTECT DPO FUA RARC Obsolete Obsolete 
2 (MSB) 
LOGICAL BLOCK ADDRESS 
5 (LSB) 
6 Reserved GROUP NUMBER 
7 (MSB) 
TRANSFER LENGTH 
8 (LSB) 
9 CONTROL 
RDPROTECT field 


The device server shall check the protection information read from the medium before returning status for the command based on the RDPRO- 
TECT field as described in table 98. 
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Table 98 RDPROTECT field (Sheet 1 of 2) 






















































































Logical unit Shall davicecerver Extended 
formatted with Zi .__ |Fieldin protection) INQUIRY Data If check fails [d] [f], 
Code i transmit protection | . i 5 a 
protection ‘i : information [h] | VPD page bit additional sense code 
s : information? 
information value [g] 
LOGICAL BLOCK GRD_CHK = 1 LOGICAL BLOCK GUARD CHECK FAILED 
GUARD 
GRD_CHK = 0 NO CHECK PERFORMED 
LOGICAL BLOCK | APP_CHK = 1 [c] | LOGICAL BLOCK APPLICATION TAG CHECK 
APPLICATION TAG FAILED 
Yes [d] No 
000b APP_CHK=0 NO CHECK PERFORMED 
LOGICAL BLOCK | per CHK =1/il | LOGICAL BLOCK REFERENCE TAG CHECK 
REFERENCE TAG 7 FAILED 
REF_CHK=0 NO CHECK PERFORMED 
No No protection information available to check 
LOGICAL BLOCK GRD_CHK = 1 LOGICAL BLOCK GUARD CHECK FAILED 
GUARD SY 
GRD_CHK = 0 NO CHECK PERFORMED 
LOGICAL BLOCK | APP_CHK= 1 [c] | LOGICAL BLOCK APPLICATION TAG CHECK 
APPLICATION TAG FAILED 
001b Yes Yes [e] C OrHEe 5 
101b [b] APP_CHK =0 NO CHECK PERFORMED 
LOGICAL BLOCK | per CHK=11il | LOGICAL BLOCK REFERENCE TAG CHECK 
REFERENCE TAG I FAILED 
REF_CHK=0 NO CHECK PERFORMED 
No [al No protection information available to transmit to the data-in buffer or for checking 
LOGICAL BLOCK NO CHECK PERFORMED 
GUARD 
LOGICAL BLOCK | APP_CHK=1 [c] | LOGICAL BLOCK APPLICATION TAG CHECK 
APPLICATION TAG FAILED 
o10b [b] i Yes [el APP_CHK =0 NO CHECK PERFORMED 
LOGICAL BLOCK | per CHK =1/il | LOGICAL BLOCK REFERENCE TAG CHECK 
REFERENCE TAG - FAILED 
REF_CHK=0 NO CHECK PERFORMED 
No fal No protection information available to transmit to the data-in buffer or for checking 
LOGICAL BLOCK NO CHECK PERFORMED 
GUARD 
Y y LOGICAL BLOCK NO CHECK PERFORMED 
o11b [b] = es le] APPLICATION TAG 
LOGICAL BLOCK NO CHECK PERFORMED 
REFERENCE TAG 
No /al No protection information available to transmit to the data-in buffer or for checking 
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Table 98 RDPROTECT field (Sheet 2 of 2) 






































Logical unit Shall device server Extended 
formatted with Zi .__ |Fieldin protection) INQUIRY Data If check fails [d] [f], 
Code i transmit protection | . i Bi ee 
protection information [h] VPD page bit additional sense code 
: % information? 
information value [g] 
LOGICAL BLOCK GRD_CHK = 1 LOGICAL BLOCK GUARD CHECK FAILED 
GUARD 
GRD_CHK = 0 NO CHECK PERFORMED 
Yes Yes [e] LOGICAL BLOCK NO CHECK PERFORMED 
100b [b] APPLICATION TAG 
LOGICAL BLOCK NO CHECK PERFORMED 
REFERENCE TAG 
No [al No protection information available to transmit to the data-in buffer or for checking 
101b - 
111b Reserved 








[a] A read operation to a logical unit that supports protection information and has not been formatted with protection information shall 
be terminated with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
INVALID FIELD IN CDB. 

[b] If the logical unit does not support protection information the requested command should be terminated with CHECK CONDITION 
status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 

[c] If the device server has knowledge of the contents of the LOGICAL BLOCK APPLICATION TAG field, then the device server shall check 
each logical block application tag. If the ATO bit in the Control mode page (see 5.3.12) is set to one, then this knowledge is acquired 
from: 
1) the EXPECTED LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in the 

CDB, if a READ (32) command (see 3.19) is received by the device server; 
2) the Application Tag mode page (see 5.3.6), if a command other than READ (32) is received by the device server, and 
the ATMPE bit in the Control mode page (see 5.3.12) is set to one; or 
3) amethod not defined by this standard, if a command other than READ (32) is received by the device server, and the 
ATMPE bit is set to zero. 

[d] Ifan error is reported, the sense key shall be set to ABORTED COMMAND. 

[e] Transmit protection information to the data-in buffer. 

[f] If multiple errors occur, the selection of which error to report is not defined by this manual. 

[g] See the Extended INQUIRY Data VPD page (see 5.4.9) for the definitions of the GRD_CHK bit, the APP_CHK bit, 
and the REF_CHK bit. 

[h] If the device server detects: 

1) aLOGICAL BLOCK APPLICATION TAG field set to FFFFh and type 1 protection (see SBC-4) or type 2 protection 

(see SBC-4) is enabled; or 

2) aLOGICAL BLOCK APPLICATION TAG field set to FFFFh, LOGICAL BLOCK REFERENCE TAG field set to FFFF FFFFh, 
and type 3 protection (see SBC-4) is enabled, then the device server shall not check any protection information in the 
associated protection information interval. 
[i] If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to the lower 4 bytes of the 
LBA associated with the logical block. If type 2 protection or type 3 protection is enabled, the device server checks the LOG- 
ICAL BLOCK REFERENCE TAG if it has knowledge of the contents of the logical block reference tag field. If type 2 protec- 
tion is enabled, then this knowledge may be acquired through the expected INITIAL LOGICAL BLOCK REFERENCE TAG 
field ina READ (32) command (see 3.19). If type 3 protection is enabled, then the method for acquiring this knowledge is 
not defined by this manual. 





[j] If the DPICZ bit in the Control mode page (see 5.3.12) is set to one, then protection information shall not be checked. 
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DPO (Disable Page Out) bit 


0 A Disable Page Out (DPO) bit set to zero specifies that the retention priority shall be determined by the RETENTION PRIORITY fields in the 
Caching mode page (see 5.3.9). 

1 A DPO bit set to one specifies that the device server shall assign the logical blocks accessed by this command the lowest retention prior- 
ity for being fetched into or retained by the cache. A DPO bit set to one overrides any retention priority specified in the Caching mode 
page. All other aspects of the algorithm implementing the cache replacement strategy are not defined by this manual. 


NOTE The DPO bit is used to control replacement of logical blocks in the cache when the application client 
has information on the future usage of the logical blocks. If the DPO bit is set to one, the application 
client is specifying that the logical blocks accessed by the command are not likely to be accessed 
again in the near future and should not be put in the cache nor retained by the cache. If the DPO bit 
is set to zero, the application client is specifying that the logical blocks accessed by this command are 
likely to be accessed again in the near future. 


FUA bit 
0 A Force unit Access (FUA) bit set to zero specifies that the device server may read the logical blocks from the volatile cache (if any), the 
specified data pattern for that LBA (e.g., the data pattern for unmapped data), the non-volatile cache, or the medium. 


1 An FUA bit set to one specifies that the device server shall read the logical blocks from the specified data pattern for that LBA, the 
non-volatile cache (if any), or the medium. If a volatile cache contains a more recent version of a logical block, then the device server 
shall write that logical block to non-volatile cache or the medium before reading the logical block. 


RARC bit 


If rebuild assist mode is supported and not enabled, then the rebuild assist recovery control (RARC) bit is ignored. If rebuild assist mode is sup- 
ported and enabled, then the RARC bit specifies that read operations are processed as defined in SBC-4. 


If the rebuild assist mode is not supported and the RARC bit is set to one, then the device server should terminate the command with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 


LOGICAL BLOCK ADDRESS field 


The LOGICAL BLOCK ADDRESS field specifies the first logical block accessed by this command. If the logical block address exceeds the capacity 
of the medium the device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. 


GROUP NUMBER field 


The GROUP NUMBER field specifies the group into which attributes associated with the command should be collected. AGROUP NUMBER field 
set to zero specifies that any attributes associated with the command shall not be collected into any group. 


TRANSFER LENGTH field 


The TRANSFER LENGTH field specifies the number of contiguous logical blocks of data that shall be read and transferred to the data-in buffer, 
starting with the logical block specified by the LOGICAL BLOCK ADDRESS field. A TRANSFER LENGTH field set to zero specifies that no logical 
blocks shall be read. This condition shall not be considered an error. Any other value specifies the number of logical blocks that shall be read. If 
the logical block address plus the transfer length exceeds the capacity of the medium, the device server shall terminate the command with 
CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF 
RANGE. The TRANSFER LENGTH field is constrained by the MAXIMUM TRANSFER LENGTH field in the Block Limits VPD page. 
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3.17 READ (12) command 


The READ (12) command (see table 99) requests that the device server read the specified logical block(s) and transfer them to 
the data-in buffer. Each logical block read includes user data and, if the medium is formatted with protection information 
enabled, protection information. Each logical block transferred includes user data and may include protection information, 
based on the RDPROTECT field and the medium format. 


Table 99 READ (12) command 



























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (A8h) 

1 RDPROTECT DPO FUA RARC Obsolete Obsolete 

2 (MSB) 

LOGICAL BLOCK ADDRESS 
5 (LSB) 
6 (MSB) 
TRANSFER LENGTH 

9 sa) 
10 sears os Reserved GROUP NUMBER 
11 CONTROL 














See the READ (10) command for the definitions of the fields in this command. 
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3.18 READ (16) command 


The READ (16) command (see table 100) requests that the device server read the specified logical block(s) and transfer them to 
the data-in buffer. Each logical block read includes user data and, if the medium is formatted with protection information 
enabled, protection information. Each logical block transferred includes user data and may include protection information, 
based on the RDPROTECT field and the medium format. 


Table 100 READ (16) command 



























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (88h) 
1 RDPROTECT DPO FUA RARC Obsolete DLD2 
2 (MSB) 
LOGICAL BLOCK ADDRESS 
9 (LSB) 
10 (MSB) 
TRANSFER LENGTH 
13 (LSB) 
14 DLD1 DLDO GROUP NUMBER 
15 CONTROL 














DLD2, DLD1 and DLDO bits 


The command duration time (see SAM-5) is specified by the command duration limit descriptor (see 5.3.10 and 5.3.11) specified by the DLD2 
bit, the DLD1 bit, and the DLDO bit, as shown in table 101. The CDLP field in the REPORT SUPPORTED OPERATION CODES parameter data (see 
SPC-5) indicates that the command duration limit descriptor is in the Command Duration Limit A mode page or the Command Duration Limit 
B mode page (see 5.3.10 and 5.3.11). 


Table 101‘ Force unit access for read operations 


























Duration limit descriptor value bits 
Command duration limit descriptor specifying command duration time 
DLD2 DLD1 DLDO 
Ob Ob Ob Command is not a duration limited command (see SAM-5) 
Ob Ob 1b First command duration limit descriptor 
Ob 1b Ob Second command duration limit descriptor 
Ob 1b 1b Third command duration limit descriptor 
1b Ob Ob Fourth command duration limit descriptor 
1b Ob 1b Fifth command duration limit descriptor 
1b 1b Ob Sixth command duration limit descriptor 
1b 1b 1b Seventh command duration limit descriptor 




















The CONTROL byte is defined in Clause 2.2.7 


See the READ (10) command for the definitions of the other fields in this command. 
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READ (32) command 


3.19 


The READ (32) command (see table 102) requests that the device server read the specified logical block(s) and transfer them to 
the data-in buffer. Each logical block read includes user data and, if the medium is formatted with protection information 
enabled, protection information. Each logical block transferred includes user data and may include protection information, 
based on the RDPROTECT field and the medium format. 


The READ (32) command shall only be processed if type 2 protection is enabled (see SBC-4). 








































































































Table 102 READ (32) command 
Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (7Fh) 

1 CONTROL 

2 
site Reserved 

5 

6 Reserved GROUP NUMBER 

7 ADDITIONAL CDB LENGTH (18h) 

8 (MSB) 

SERVICE ACTION (0009h) 
9 (LSB) 
10 RDPROTECT DPO FUA RARC Obsolete Reserved 
11 Reserved 
12 (MSB) 
eas LOGICAL BLOCK ADDRESS 
19 (LSB) 
20 (MSB) 
for EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 
23 (LSB) 
24 (MSB) 
EXPECTED LOGICAL BLOCK APPLICATION TAG 
25 (LSB) 
26 (MSB) 
LOGICAL BLOCK APPLICATION TAG MASK 

27 (LSB) 
28 (MSB) 
oak TRANSFER LENGTH 
31 (LSB) 














SCSI Commands Reference Manual, Rev. J 


142 


www.seagate.com Direct Access Block commands (SPC-5 and SBC-4) 


See the READ (10) command for the definitions of the GROUP NUMBER field, the RDPROTECT field, the DPO bit, the FUA bit, the 
RARC bit, the LOGICAL BLOCK ADDRESS field, and the TRANSFER LENGTH field. 


EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG field 


When checking of the LOGICAL BLOCK REFERENCE TAG field is enabled (see table 98), the EXPECTED INITIAL LOGICAL BLOCK 
REFERENCE TAG field contains the value of the LOGICAL BLOCK REFERENCE TAG field expected in the protection information of 
the first logical block accessed by the command instead of a value based on the LBA. 


EXPECTED LOGICAL BLOCK APPLICATION TAG and LOGICAL BLOCK APPLICATION TAG MASK fields 


If the ATO bit in the Control mode page (see 5.3.12) is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK 
APPLICATION TAG field is enabled (see table 98), the LOGICAL BLOCK APPLICATION TAG MASK field contains a value that is a bit mask for 
enabling the checking of the LOGICAL BLOCK APPLICATION TAG field in the protection information for each logical block accessed by the com- 
mand. A LOGICAL BLOCK APPLICATION TAG MASK field bit set to one enables the checking of the corresponding bit of the EXPECTED LOGICAL 
BLOCK APPLICATION TAG field with the corresponding bit of the LOGICAL BLOCK APPLICATION TAG field in the protection information. 


If the ATO bit is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK APPLICATION TAG field is disabled (see 
table 98), or if the ATO bit is set to zero, the LOGICAL BLOCK APPLICATION TAG MASK field and the EXPECTED LOGICAL BLOCK APPLICATION 
TAG field shall be ignored. 
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3.20 READ BUFFER (10) command 


3.20.1 READ BUFFER (10) command introduction 


The READ BUFFER (10) command (see table 103) is used in conjunction with the WRITE BUFFER command as a diagnostic 
function for testing memory in the SCSI device and the integrity of the service delivery subsystem. This command shall not alter 
the medium. 


Table 103 READ BUFFER (10) command 





















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (3Ch) 

1 MODE SPECIFIC MODE 

2 BUFFER ID 

3 (MSB) 
Sine BUFFER OFFSET 

5 (LSB) 
6 (MSB) 
ALLOCATION LENGTH 

8 (LSB) 
9 CONTROL 








MODE SPECIFIC field 
The usage of the MODE SPECIFIC field depends on the value in the MODE field. 


MODE field 


The function of this command and the meaning of fields within the CDB depend on the contents of the MoDE field. The mope field is defined in 
table 104. 


Table 104 MODE field 




















MODE Description 
00h Combined header and data '*! 
Oth Not supported !! 
02h Data 
03h Descriptor 

04h - 09h Reserved 
OAh Echo buffer 
OBh Echo buffer descriptor 
0Ch- 19h Reserved 
1Ah Obsolete 
1Bh Reserved 
1Ch Error history 
1Dh - 1Fh Reserved 
[a] Mode 00h and 01h are not recommended. 
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ALLOCATION LENGTH field 
If the MODE field is not set to one, the ALLOCATION LENGTH field is defined in 2.2.6. 


CONTROL byte 
The CONTROL byte is defined in Clause 2.2.7. 


3.20.2 Combined header and data mode (00h) 
The four-byte READ BUFFER header (see table 105) is followed by data bytes from the buffer. 


Table 105 READ BUFFER header 





Bit 7 6 5 4 3 2 1 0 

Byte 
0 Reserved 
1 (MSB) 
































cee BUFFER CAPACITY 
3 (LSB) 








DATA 














n 





BUFFER CAPACITY field 

The BUFFER CAPACITY field specifies the total number of data bytes available in the buffer. The buffer capacity is not reduced to reflect the 
actual number of bytes written using the WRITE BUFFER command with combined header and data mode. The relationship between the BUF- 
FER CAPACITY field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. Following the READ BUFFER header, the device server shall 
transfer data from the buffer. 


3.20.3 Vendor specific mode (01h) 


This mode is not supported by Seagate products. If used, the drive will return CHECK CONDITION and report an ILLEGAL 
REQUEST/INVALID FIELD IN CDB error. 


3.20.4 Data mode (02h) 


In this mode, the Data-In Buffer is filled only with logical unit buffer data. The BUFFER ID field specifies a buffer within the logical 
unit from which data shall be transferred. Seagate assigns buffer ID codes to buffers within the logical unit. Buffer ID zero shall be 
supported. If more than one buffer is supported, then additional buffer ID codes shall be assigned contiguously, beginning with 
one. Buffer ID code assignments for the READ BUFFER command shall be the same as for the WRITE BUFFER command. If an 
unsupported buffer ID code is selected, then the command shall be terminated with CHECK CONDITION status, with the sense 
key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


The BUFFER OFFSET field contains the byte offset within the specified buffer from which data shall be transferred. The 
application client should conform to the offset boundary requirements returned in the READ BUFFER descriptor (see 3.20.5). If 
the device server is unable to accept the specified buffer offset, the command shall be terminated with CHECK CONDITION 
status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 
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3.20.5 Descriptor mode (03h) 


In this mode, a maximum of four bytes of READ BUFFER descriptor information is returned. The device server shall return the 
descriptor information for the buffer specified by the BUFFER ID field (see the description of the buffer ID in 3.20.4). If there is no 
buffer associated with the specified buffer ID, the device server shall return all zeros in the READ BUFFER descriptor. The BUFFER 
OFFSET field is reserved in this mode. The allocation length should be set to four or greater. The READ BUFFER descriptor is 
defined as shown in table 106. 


Table 106 READ BUFFER descriptor 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OFFSET BOUNDARY 

1 (MSB) 

oe BUFFER CAPACITY 

3 (LSB) 
OFFSET BOUNDARY field 


The OFFSET BOUNDARY field returns the boundary alignment within the selected buffer for subsequent WRITE BUFFER and READ BUFFER 
commands. The value contained in the OFFSET BOUNDARY field shall be interpreted as a power of two. 
For READ BUFFER commands, the OFFSET BOUNDARY field (see table 107) applies to the following modes: 

a) data (i.e., 02h) (see 3.20.4); and 

b) error history (i.e., 1Ch) (see 3.20.8) 


The value contained in the BUFFER OFFSET field of subsequent WRITE BUFFER and READ BUFFER commands should be a 
multiple of 2°ffset boundary 5° chown in table 107. 


Table 107 Buffer offset boundary 











Offset boundary pois boumas y) Buffer offsets 
Oh 20-4 Byte boundaries 
th >) Even-byte boundaries 
2h 22-4 Four-byte boundaries 
3h 23-8 Eight-byte boundaries 
4h 24-16 16-byte boundaries 
FFh Not applicable 0 is the only supported buffer offset 











BUFFER CAPACITY field 


The BUFFER CAPACITY field shall return the maximum size of the selected buffer in bytes. This capacity value only apples to data mode (i.e., 
MODE field set to 02h). 


NOTE Ina system employing multiple application clients, a buffer may be altered between the WRITE 
BUFFER and READ BUFFER commands by another application client. Buffer testing applications 
should ensure that only a single application client is active. Use of reservations to all logical units on 
the device or linked commands may be helpful in avoiding buffer alteration between these two 
commands. 
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3.20.6 Echo buffer mode (OAh) 


In this mode the device server transfers data to the application client from the echo buffer that was written by the most recent 
WRITE BUFFER command with the mode field set to echo buffer received on the same I_T nexus. The READ BUFFER command 
shall return the same number of bytes of data as received in the prior WRITE BUFFER command with the mode field set to echo 
buffer, limited by the allocation length. The BUFFER ID and BUFFER OFFSET fields are ignored in this mode. 


If no WRITE BUFFER command with the mode set to echo buffer received on this |_T nexus has completed without an error, then 
the READ BUFFER command shall terminate with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the 
additional sense code set to COMMAND SEQUENCE ERROR. If the data in the echo buffer has been overwritten by another |_T 
nexus, the READ BUFFER command shall be terminated with CHECK CONDITION status, with the sense key set to ABORTED 
COMMAND, and the additional sense code set to ECHO BUFFER OVERWRITTEN. 


After a WRITE BUFFER command with the mode set to echo buffer has completed without an error, the application client may 
send multiple READ BUFFER commands with the mode set to echo buffer in order to read the echo buffer data multiple times. 


3.20.7 Echo buffer descriptor mode (OBh) 


In this mode, a maximum of four bytes of READ BUFFER descriptor information is returned. The device server shall return the 
descriptor information for the echo buffer. If there is no echo buffer implemented, the device server shall return all zeros in the 
READ BUFFER descriptor. The BUFFER ID field and BUFFER OFFSET field are reserved in this mode. The allocation length should be 
set to four or greater. The READ BUFFER descriptor is defined as shown in table 108. 


Table 108 Echo buffer descriptor 









































Bit 7 6 5 4 3 2 1 0 
Byte 

0 Reserved EBOS 

1 Reserved 

2 Reserved (MSB) 

3 BUFFER CAPACITY (LSB) 














BUFFER CAPACITY field 


The BUFFER CAPACITY field shall return the size of the echo buffer in bytes aligned to a four-byte boundary. The maximum echo buffer size is 4 
096 bytes. 


If the echo buffer is implemented, the echo buffer descriptor shall be implemented. 


EBOS bit 
1 An echo buffer overwritten supported (EBOS) bit set to one indicates either: 


a) The device server returns the ECHO BUFFER OVERWRITTEN additional sense code if the data being read from the echo buffer is not 
the data previously written by the same |_T nexus, or 


b) The device server ensures echo buffer data returned to each |_T nexus is the same as that previously written by that |_T nexus. 


0 = AnEBOS bit set to zero specifies that the echo buffer may be overwritten by any intervening command received on any I_T nexus. 


A READ BUFFER command with the mode set to echo buffer descriptor may be used to determine the echo buffer capacity and 
supported features before a WRITE BUFFER command with the mode set to echo buffer is sent. 
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3.20.8 


3.20.8.1 


Error history mode (1Ch) 


Error history overview 


This mode is used to manage and retrieve error history (see SPC-5). 


Direct Access Block commands (SPC-5 and SBC-4) 


If the device server is unable to process a READ BUFFER command with the mopbe field set to 1Ch because of a vendor specific 
condition, then the device server shall terminate the READ BUFFER command with CHECK CONDITION status, with the sense key 
set to ILLEGAL REQUEST, and the additional sense code set to COMMAND SEQUENCE ERROR. 


The BUFFER ID field (see table 109) specifies the action that the device server shall perform, and the parameter data, if any, that 
the device server shall return. 
































Table 109 _ Error history BUFFER ID field 
Error history 
Code Description Buffer offset |_T nexus Reference 
constrained 
00h Return error history directory 0000h Yes 3.20.8.2 
Oth Return error history directory and create new 0000h Yes 3.20.8.2 
error history snapshot (see 1.1 and SPC-5) 
02h Return error history directory and establish new 0000h No 3.20.8.2 
error history |_T nexus (see 1.1 and SPC-5) 
Return error history directory, establish new 0000h No 3.20.8.2 
03h error history |_T nexus, and create new error his- 
tory snapshot 
04h to OFh Reserved Yes 
10h to EFh Return error history 0000h to FFFFh Yes 3.20.8.3 
FOh to FDh Reserved Yes 
FEh Clear error history |_T nexus Ignored Yes 3.20.8.4 
FFh Clear error history |_T nexus and release error Ignored Yes 3.20.8.5 
history snapshot 























The command shall be terminated with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional 


sense code set to OPERATION IN PROGRESS if the device server receives a READ BUFFER command: 


a) with the mope field set to 1Ch; 
b) with the BUFFER ID field set to a value that table 109 shows as constrained by error history |_T nexus; 
c) ifanerror history |_T nexus exists and the command is received from an |_T nexus that is different that |_T nexus; and 
d) anerror history snapshot exists. 
BUFFER OFFSET field 


The BUFFER OFFSET field specifies the byte offset from the start of the buffer specified by the BUFFER ID field from which the device server shall 
return data. The application client should conform to the offset boundary requirements indicated in the READ BUFFER descriptor (see 3.20.5). If 
the buffer offset is not one of those shown in table 109 or the device server is unable to accept the specified buffer offset, then the device 
server shall terminate the READ BUFFER command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the addi- 
tional sense code set to INVALID FIELD IN CDB. 
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3.20.8.2. Error history directory 


Whenever allowed by established error history |_T nexus constraints (see 3.20.8.1), if any, all error history device server actions return an error 
history directory (see table 112). Some error history device server actions also discard the existing error history snapshot (see SPC-5) and create a 
new error history snapshot (see table 110). 


Table 110 Summary of error history directory device server actions 

















i i Error history snapsh PC- 
BUFFER ID field Se ee ep een LT Pe ae 'y snapshot (see S a 
00h No [al Yes No [® 
Oth No [al No Yes 
02h Yes Yes No /b1 
03h Yes No Yes 














[a] If no error history |_T nexus is established, a new one is established. 





{b] If no error history snapshot exists, a new one is created. 








Table 111 defines the meaning of the combinations of values for the BUFFER ID field and the MODE SPECIFIC field for the error 


history mode. 


Table 111 BUFFERID field and MODE SPECIFIC field meanings for the error history mode 


BUFFERID | MODE SPECIFIC 


Description 




















field field 
If a new error history snapshot is created (see table 110), vendor specific parameter data 
000b shall be created (i.e., at least one error history directory entry (see table 115) shall contain a 
BUFFER FORMAT field that is set to 00h). 
00h to 03h If a new error history snapshot is created (see table 110), current internal status parameter 
001b data shall be created (i.e., at least one error history directory entry (see table 115) shall 
contain a BUFFER FORMAT field that is set to 01h). 
010b to 111b Reserved 
All others 000b to 111b Reserved 
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The error history directory is defined in table 112. 
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Table 112 —_ Error history directory 
Bit 7 6 5 4 3 2 1 oO 
Byte 
0 (MSB) 
T10 VENDOR IDENTIFICATION 

7 (LSB) 
8 VERSION 

9 Reserved EHS_RETRIEVED EHS_SOURCE CLR_SUP 
10 

Reserved 
29 
30 (MSB) 
DIRECTORY LENGTH (n-31) 
31 (LSB) 
Error history directory list 
32 
Error history directory entry [first] 
(see table 115) 
39 
n-7 
Error history directory entry [last] 
(see table 115) 
n 














T10 VENDOR IDENTIFICATION field 


The T10 VENDOR IDENTIFICATION field contains eight bytes of left-aligned ASCII data identifying the manufacturer of the logical unit. The T10 
vendor identification shall be one assigned by INCITS. 


NOTE The 110 VENDOR IDENTIFICATION field may contain a different value than the VENDOR 
IDENTIFICATION field in the standard INQUIRY data (see 3.6.2) (e.g., this field may indicate a disk drive 
component vendor while the standard INQUIRY data indicates the original equipment 
manufacturer). 

VERSION field 


The VERSION field indicates the version and format of the vendor specific error history. The VERSION field is assigned by the vendor indicated in 
the T10 VENDOR IDENTIFICATION field. 


SCSI Commands Reference Manual, Rev. J 


150 


www.seagate.com Direct Access Block commands (SPC-5 and SBC-4) 


EHS_RETRIEVED (error history retrieved) field 


The error history retrieved (EHS_RETRIEVED) field (see table 113) indicates whether a clear error history device server action has been 
requested for the error history snapshot. EHS_RETRIEVED field shall be set to 0Ob or 10b when the error history snapshot is created. 


Table 113. EHS_RETRIEVED field 











Code Description 
00b No information 
01b The error history |_T nexus has requested buffer ID FEh (i.e., clear error history |_T nexus) or buffer ID FFh (i-e., clear 


error history |_T nexus and release snapshot) for the current error history snapshot. 





10b An error history |_T nexus has not requested buffer ID FEh (i.e., clear error history |_T nexus) or buffer ID FFh (i.e., 
clear error history |_T nexus and release snapshot) for the current error history snapshot. 














11b Reserved 





EHS_SOURCE (error history source) field 
The error history source (EHS_ SOURCE) field (see table 114) indicates the source of the error history snapshot. 


Table 114 EHS SOURCE field 














Code Description 
00b The error history snapshot was created by the device server and was not created due to processing a READ BUF- 
FER command. 
01b Error history snapshot was created due to processing of the current READ BUFFER command 
10b Error history snapshot was created due to processing of a previous READ BUFFER command 
11b Reserved 











CLR_SUPC (clear support) bit 


1 A clear support (CLR_SUP) bit set to one indicates that the CLR bit is supported in the WRITE BUFFER command download error history 
mode (see 3.70). 


O ACLR_SUP bit set to zero indicates that the CLR bit is not supported. 


DIRECTORY LENGTH field 


The DIRECTORY LENGTH field indicates the number of error history directory list bytes available to be transferred. This value shall not be altered 
even if the allocation length is not sufficient to transfer the entire error history directory list. 
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The error history directory list contains an error history directory entry (see table 115) for each supported buffer ID in the range of 00h to EFh. The 
first entry shall be for buffer ID 00h and the entries shall be in order of ascending buffer IDs. The supported buffer IDs are not required to be 
contiguous. There shall not be any entries for buffer IDs greater than or equal to FOh. 


Table 115 Error history directory entry 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 SUPPORTED BUFFER ID 

1 BUFFER FORMAT 

2 Reserved BUFFER SOURCE 

3 Reserved 

4 (MSB) 

MAXIMUM AVAILABLE LENGTH 
7 (LSB) 








SUPPORTED BUFFER ID field 
The SUPPORTED BUFFER ID field indicates the error history buffer ID associated with this entry. 


BUFFER FORMAT field 


If the SUPPORTED BUFFER ID field is set to 10h to EFh, the BUFFER FORMAT field (see table 116) indicates the format of the parameter data for 
the error history buffer indicated by the SUPPORTED BUFFER ID field. If the SUPPORTED BUFFER ID field is not set to 10h to EFh, the BUFFER 
FORMAT field should be ignored by the application client. 


Table 116 BUFFER FORMAT field 























Code Description sic 
00h Contains vendor specific data 
O1h Contains current internal status parameter data see SPC-5 
02h Contains saved internal status parameter data see SPC-5 
Allothers | Reserved 
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BUFFER SOURCE field 


If the SUPPORTED BUFFER ID field is set to 10h to EFh, the BUFFER SOURCE field (see table 117) indicates the source field the error history buffer 
indicated by the SUPPORTED BUFFER ID field. If the SUPPORTED BUFFER ID field is set to 10h to EFh, the BUFFER SOURCE field should be 
ignored by the application client. 


Table 117 BUFFER SOURCE field 














Code Description 
Oh The source is indicated in the EHS_SOURCE field in the error history directory (see table 112). 
th The source is unknown. 
2h The error history information was: 


a) created by the device server as the result of a vendor specific event; and 
b) not created due to processing of a READ BUFFER command. 





3h The error history information was created due to the processing of the current READ BUFFER command. 





Ah The error history information was created due to the processing of a previous READ BUFFER command. 











All others Reserved 


MAXIMUM AVAILABLE LENGTH 


The MAXIMUM AVAILABLE LENGTH field indicates the maximum number of data bytes contained in the buffer indicated by the SUPPORTED 
BUFFER ID field. The actual number of bytes available for transfer may be smaller. 


3.20.8.3 Error history data buffer 


3.20.8.3.1 Overview 


Unless an error is encountered, the device server shall return parameter data that contains error history from the error history 
snapshot from the specified buffer at the specified buffer offset. The parameter data shall be formatted as indicated by the 
BUFFER FORMAT field in the error history directory entry (see table 115) associated with the buffer ID specified by the READ 
BUFFER command. 


If the device server receives a READ BUFFER command with the MODE field set to 1Ch from the established error history |_T 
nexus and the BUFFER ID field is set to a value that the error history directory (see 3.20.8.2) shows as not supported, then the 
device server shall be terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID FIELD IN CDB. 


If the value in the BUFFER OFFSET field is not supported, the device server shall terminate the command with CHECK CONDITION 
status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 


The amount of error history in the specified buffer shall be less than or equal to the number of bytes indicated by the MAXIMUM 
AVAILABLE LENGTH field in the error history directory (see 3.20.8.2). 


3.20.8.4 Clear error history |_T nexus 
If the BUFFER ID field is set to FEh, the device server shall: 


a) clear the error history |_T nexus, if any; and 
b) not transfer any data. 


3.20.8.5 Clear error history I|_T nexus and release snapshot 
If the BUFFER ID field is set to FFh, the device server shall: 


a) clear the error history |_T nexus, if any, 
b) release the error history snapshot, if any; and 
c) not transfer any data. 
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3.21 READ BUFFER (16) command 


The READ BUFFER (16) command (see table 118) requests that the device server perform the actions defined for the READ 
BUFFER (10) command (see 3.20). 


Table 118 READ BUFFER (16) command 
























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (9Bh) 

1 MODE SPECIFIC MODE 

2 (MSB) 

Kis BUFFER OFFSET 

9 (LSB) 
10 (MSB) 
aces ALLOCATION LENGTH 

13 (LSB) 
14 BUFFER ID 

15 CONTROL 














OPERATION CODE field 


The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the value defined in 
table 118. 


MODE SPECIFIC field, MODE field, BUFFER OFFSET field, ALLOCATION LENGTH field, and BUFFER ID field 
The MODE SPECIFIC field, MODE field, BUFFER OFFSET field, ALLOCATION LENGTH field, and BUFFER ID field are defined in 3.20. 


CONTROL byte 
The CONTROL byte is defined in Clause 2.2.7. 
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3.22 


3.22.1 


READ CAPACITY (10) command 


READ CAPACITY (10) overview 


Direct Access Block commands (SPC-5 and SBC-4) 


The READ CAPACITY (10) command (see table 119) requests that the device server transfer 8 bytes of parameter data describing the capacity 
and medium format of the direct-access block device to the data-in buffer. This command may be processed as if it has a HEAD OF QUEUE task 
attribute. If the logical unit supports protection information, the application client should use the READ CAPACITY (16) command instead of the 
READ CAPACITY (10) command. 


Table 119 READ CAPACITY (10) command 






























































Bit 7 6 5 4 3 0 
Byte 
0 OPERATION CODE (25h) 
1 Reserved Obsolete 
2 (MSB) 
LOGICAL BLOCK ADDRESS (Obsolete) 
5 (LSB) 
6 
Reserved 
7 
PMI 

8 

Reserved (Obsolete) 
9 CONTROL 








For the definition of the LOGICAL BLOCK ADDRESS field see 2.2.3. 


LOGICAL BLOCK ADDRESS field 


This field has been declared obsolete by the T10 committee. However, it is included because it may be implemented on some products. 


The LOGICAL BLOCK ADDRESS field shall be set to zero if the PMI bit is set to zero. If the PMI bit is set to zero and the LOGICAL BLOCK ADDRESS 
field is not set to zero, the device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL 
REQUEST and the additional sense code set to INVALID FIELD IN CDB. 


PMI (Partial Medium Indicator) bit 


This bit has been declared obsolete by the T10 committee. However, it is included because it may be implemented on some products. 


0 


A partial medium indicator (PMI) bit set to zero specifies that the device server return information on the last logical block on the 


direct-access block device. 


A PMI bit set to one specifies that the device server return information on the last logical block after that specified in the LOGICAL BLOCK 


ADDRESS field before a substantial vendor-specific delay in data transfer may be encountered. 


This function is intended to assist storage management software in determining whether there is sufficient space starting with the logical 
block address specified in the CDB to contain a frequently accessed data structure (e.g., a file directory or file index) without incurring an extra 


delay. 


SCSI Commands Reference Manual, Rev. J 


155 


www.seagate.com Direct Access Block commands (SPC-5 and SBC-4) 


3.22.2 READ CAPACITY (10) parameter data 


The READ CAPACITY (10) parameter data is defined in table 120. Any time the READ CAPACITY (10) parameter data changes, the device server 
should establish a unit attention condition as described in SBC-4. 


Table 120 READ CAPACITY (10) parameter data 





Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 





RETURNED LOGICAL BLOCK ADDRESS 





3 (LSB) 





4 (MSB) 





BLOCK LENGTH IN BYTES 














7 (LSB) 





RETURNED LOGICAL BLOCK ADDRESS field 


If the number of logical blocks exceeds the maximum value that is able to be specified in the RETURNED LOGICAL BLOCK ADDRESS field, the 
device server shall set the RETURNED LOGICAL BLOCK ADDRESS field to FFFFFFFFh. The application client should then issue a READ CAPACITY 
(16) command (see 3.24) to retrieve the READ CAPACITY (16) parameter data. 


0 If the PMI bit is set to zero, the device server shall set the RETURNED LOGICAL BLOCK ADDRESS field to the lower of: 
a) the LBA of the last logical block on the direct-access block device; or 
b) FFFFFFFFh. 

1 If the PMI bit is set to one, the device server shall set the RETURNED LOGICAL BLOCK ADDRESS field to the lower of: 


a) the last LBA after that specified in the LOGICAL BLOCK ADDRESS field of the CDB before a substantial vendor-specific delay in data 
transfer may be encountered; or 


b) the LBA of the last logical block on the direct-access block device. 
The RETURNED LOGICAL BLOCK ADDRESS shall be greater than or equal to that specified by the LOGICAL BLOCK ADDRESS field in the CDB. 


BLOCK LENGTH IN BYTES field 


The BLOCK LENGTH IN BYTES field contains the number of bytes of user data in the logical block indicated by the RETURNED LOGICAL BLOCK 
ADDRESS field. This value does not include protection information or additional information (e.g., ECC bytes) recorded on the medium. 


SCSI Commands Reference Manual, Rev. J 156 


www.seagate.com 


3.23 


3.23.1 


SERVICE ACTION IN operation code. This command may be processed as if it has a HEAD OF QUEUE task attribute. 


Direct Access Block commands (SPC-5 and SBC-4) 


READ CAPACITY (16) command 


READ CAPACITY (16) command overview 


The READ CAPACITY (16) command (see table 121) requests that the device server transfer parameter data describing the capacity 
and medium format of the direct-access block device to the data-in buffer. This command is mandatory if the logical unit 
supports protection information and optional otherwise (see SBC-4). This command is implemented as a service action of the 





















































Table 121 READ CAPACITY (16) command 
Bit 7 6 5 4 3 2 0 
Byte 

0 OPERATION CODE (9Eh) 

1 Reserved SERVICE ACTION (10h) 

2 (MSB) 

LOGICAL BLOCK ADDRESS (Obsolete) 
9 (LSB) 
10 (MSB) 
ALLOCATION LENGTH 

13 (LSB) 
14 Reserved gis 
15 CONTROL 














LOGICAL BLOCK ADDRESS field and PMI bit 


See 2.2.3 for the definition of the LOGICAL BLOCK ADDRESS field. 
See the READ CAPACITY (10) command (see 3.22) for the definition of the PMI bit. 


ALLOCATION LENGTH field 


The ALLOCATION LENGTH field (see 2.2.6) specifies the maximum number of bytes that the application client has allocated for returned param- 
eter data. An allocation length of zero indicates that no data shall be transferred. This condition shall not be considered as an error. The device 
server shall terminate transfers to the data-in buffer when the number of bytes specified by the ALLOCATION LENGTH field have been trans- 
ferred or when all available data has been transferred, whichever is less. The contents of the parameter data shall not be altered to reflect the 
truncation, if any, that results from an insufficient allocation length. 
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3.23.2 READ CAPACITY (16) parameter data 


The READ CAPACITY (16) parameter data is defined in table 122. Any time the READ CAPACITY (16) parameter data changes, the device server 
should establish a unit attention condition as described in SPC-5. 


Table 122 READ CAPACITY (16) parameter data 















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
7 RETURNED LOGICAL BLOCK ADDRESS 
7 (SB) 
8 (MSB) 
aie LOGICAL BLOCK LENGTH IN BYTES 
11 (LSB) 
12 Reserved RC BASIS P_TYPE PROT_EN 
13 P_l_EXPONENT LOGICAL BLOCKS PER PHYSICAL BLOCK EXPONENT 
14 LBPME LBPRZ (MSB) 
LOWEST ALIGNED LOGICAL BLOCK ADDRESS —_——_ 
15 (LSB) 
16 
sre Reserved 
31 











RETURNED LOGICAL BLOCK ADDRESS field 

The RETURNED LOGICAL BLOCK ADDRESS field and LOGICAL BLOCK LENGTH IN BYTES field of the READ CAPACITY (16) parameter data are the 
same as the in the READ CAPACITY (10) parameter data (see 3.22.1). The maximum value that shall be returned in the RETURNED LOGICAL 
BLOCK ADDRESS field is FFFFFFFF_FFFFFFFEh. 

LOGICAL BLOCK LENGTH IN BYTES field 


The LOGICAL BLOCK LENGTH IN BYTES field contains the number of bytes of user data in the logical block indicated by the RETURNED LOGICAL 
BLOCK ADDRESS field. This value does not include protection information or additional information (e.g., ECC bytes) recorded on the medium. 


RC BASIS field 


The RC BASIS field indicates the meaning of the value returned by the RETURNED LOGICAL BLOCK ADDRESS field in the READ CAPACITY (16) 
parameter data and is described in table 123. 


Table 123 RCBASIS field 





Code DESCRIPTION 


00b | The RETURNED LOGICAL BLOCK ADDRESS field indicates the highest LBA of a contiguous 
range of zones that are not sequential write required zones starting with the first zone. 


01b | The RETURNED LOGICAL BLOCK ADDRESS field indicates the LBA of the last logical block 
on the logical unit. 











10b Reserved 





11 Reserved 
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P_TYPE (Protection Type) field and PROT_EN bit 
The protection type (P_TYPE) field and the PROT_EN bit (see table 124) indicate the logical unit's current type of protection. 


Table 124 P_TYPE FIELD and PROT_EN bit 




















PROT_EN P_TYPE DESCRIPTION 
0 XXXb The logical unit is formatted to type 0 protection (see SBC-4) 
1 000b The logical unit is formatted to type 1 protection (see SBC-4) 
1 001b The logical unit is formatted to type 2 protection (see SBC-4) 
1 010b The logical unit is formatted to type 3 protection (see SBC-4) 
1 011b-111b Reserved 

















P_I|_EXPONENT field 


The P_|_EXPONENT field may be used to determine the number of protection information intervals placed within each logical 
block (see 3.3.2). 


The number of protection information intervals is calculated as follows: 
number of protection information intervals = 2'P—! exponent) 

where: p_iexponent __ is the contents of the P_| EXPONENT field 

LOGICAL BLOCKS PER PHYSICAL BLOCKS EXPONENT field 

The LOGICAL BLOCKS PER PHYSICAL BLOCKS EXPONENT field is defined in table 125. 


Table 125 LOGICAL BLOCKS PER PHYSICAL BLOCKS EXPONENT field 











Code Description 
0 One or more physical blocks per logical block!@! 

n>0 2" logical blocks per physical block 

[a] The number of physical blocks per logical block is not reported. 








Logical Block Provisioning Management Enabled (LBPME) bit 
1 If the thin provisioning enabled (TPE) bit is set to one, then the logical unit implements logical block provisioning management (see 
SBC-4). 
0 If the TPE bit is set to zero, then the logical unit does not implement logical block provisioning management (see SBC-4). 


Logical Block Provisioning Read Zeros (LBPRZ) bit 


1 If the logical block provisioning read zeros (LBPRZ) bit is set to one, then, for an unmapped LBA specified by a read operation, the device 
server shall send user data with all bits set to zero to the data-in buffer. 


0 If the TPRZ bit is set to zero, then, for an unmapped LBA specified by a read operation, the device server may send user data with all bits 
set to any value to the data-in buffer. 


LOWEST ALIGNED LOGICAL BLOCK ADDRESS field 


The LOWEST ALIGNED LOGICAL BLOCK ADDRESS field indicates the LBA of the first logical block that is located at the beginning of a physical 
block (SBC-4). 
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3.24 


3.24.1 


READ DEFECT DATA (10) command 


READ DEFECT DATA (10) command overview 


Direct Access Block commands (SPC-5 and SBC-4) 


The READ DEFECT DATA (10) command (see table 126) requests that the device server transfer the medium defect data to the 
data-in buffer. 


Table 126 READ DEFECT DATA (10) command 

































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (37h) 

1 Reserved 

2 Reserved REQ_PLIST REQ_GLIST DEFECT LIST FORMAT 

3 
aes Reserved 

6 

7 (MSB) 

ALLOCATION LENGTH 

8 (LSB) 
9 CONTROL 











If the device server is unable to access the medium defect data, it shall terminate the command with CHECK CONDITION status. 
The sense key shall be set to either MEDIUM ERROR, if a medium error occurred, or NO SENSE, if medium defect data does not 
exist. The additional sense code shall be set to DEFECT LIST NOT FOUND. 


REQ PLIST (request primary defect list) bit 
0  Arequest primary defect list (REQ_PLIST) bit set to zero specifies that the device server shall not return the PLIST. 
1 A REQ_PLIST bit set to one specifies that the device server shall return the PLIST, if any. 


REQ_GLIST (request grown defect list) bit 
0 A request grown defect list (REQ_GLIST) bit set to zero specifies that the device server shall not return the GLIST. 
1 A REQ_GLIST bit set to one specifies that the device server shall return the GLIST, if any. 


AREQ_PLIST bit set to zero and a REQ_GLIST bit set to zero specifies that the device server shall return only the defect list header 
(i.e., the first four bytes of the defect list). 


A REQ_PLIST bit set to one and a REQ_GLIST bit set to one specifies that the device server shall return both the PLIST and GLIST, 
if any. The order the lists are returned in is vendor-specific. Whether the lists are merged or not is vendor-specific. 


DEFECT LIST FORMAT field 


The DEFECT LIST FORMAT field specifies the preferred format for the defect list. This field is intended for those device servers capable of return- 
ing more than one format, as defined in the FORMAT UNIT command (see 3.3.5). A device server unable to return the requested format shall 
return the defect list in its default format and indicate that format in the DEFECT LIST FORMAT field in the defect list header (see table 126). 


If the requested defect list format and the returned defect list format are not the same, the device server shall transfer the defect data and then 
terminate the command with CHECK CONDITION status with the sense key set to RECOVERED ERROR and the additional sense code set to 
DEFECT LIST NOT FOUND. 


ALLOCATION LENGTH field 


The ALLOCATION LENGTH field is defined in 2.2.6. The application client is responsible for comparing the allocation length requested in the 
CDB with the defect list length returned in the parameter data to determine whether a partial list was received. If the number of address 
descriptors the device server has to report exceeds the maximum value that is able to be specified in the ALLOCATION LENGTH field, the device 
server shall transfer no data and return CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set 
to INVALID FIELD IN CDB. 
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3.24.2 READ DEFECT DATA (10) parameter data 


The READ DEFECT DATA (10) parameter data (see table 127) contains a four-byte header, followed by zero or more address descriptors. 


Table 127 READ DEFECT DATA (10) parameter data 





























Bit 7 6 5 4 3 2 1 0 
Byte 
0 Reserved 
1 Reserved PLISTV GLISTV DEFECT LIST FORMAT 
2 (MSB) 
DEFECT LIST LENGTH (N - 3) 
3 (LSB) 
Defect List (if any) 
4 





ADDRESS DESCRIPTOR(S) (IF ANY) 

















PLISTV (PLIST valid) bit 
0 A PLIST valid (PLISTV) bit set to zero indicates that the data returned does not contain the PLIST. 
1 A PLISTV bit set to one indicates that the data returned contains the PLIST. 


GLISTV (GLIST valid) bit 
0 AGLIST valid (GLISTV) bit set to zero indicates that the data returned does not contain the GLIST. 
1 A GLISTV bit set to one indicates that the data returned contains the GLIST. 


DEFECT LIST FORMAT field 
The DEFECT LIST FORMAT field indicates the format of the address descriptors returned by the device server. This field is defined in the FORMAT 
UNIT command (see 3.3.5). 


If the device server returns short block format address descriptors or long block format address descriptors, the address 
descriptors contain vendor-specific values. 


NOTE = The use of the short block format and the long block format is not recommended for this command. 
There is no standard model that defines the meaning of the block address of a defect. In the usual 
case, a defect that has been reassigned no longer has an LBA. 


If the device server returns physical sector format address descriptors (see 3.3.5.7), it may or may not include defects in parts of 
the medium not accessible to the application client. If the device server returns bytes from index format address descriptors (see 
3.3.5.6), it shall return a complete list of the defects. A complete list of the defects may include defects in areas not within the 
capacity returned in the READ CAPACITY command. 


DEFECT LIST LENGTH field 


The DEFECT LIST LENGTH field indicates the length in bytes of the address descriptors that follow. The DEFECT LIST LENGTH is equal to four or 
eight times the number of the address descriptors, depending on the format of the returned address descriptors. 


The address descriptors may or may not be sent in ascending order. 
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3.25 READ DEFECT DATA (12) command 


3.25.1 READ DEFECT DATA (12) command overview 


The READ DEFECT DATA (12) command (see table 128) requests that the device server transfer the medium defect data to the 
data-in buffer. 


Table 128 READ DEFECT DATA (12) command 





















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (B7h) 

1 Reserved REQ_PLIST REQ_GLIST DEFECT LIST FORMAT 

2 
esos ADDRESS DESCRIPTOR INDEX 

5 

6 (MSB) 

ALLOCATION LENGTH 

9 (LSB) 
10 Reserved 
11 CONTROL 








See the READ DEFECT DATA (10) command (see 3.24) for the definitions of the fields in this command that are not described in this clause. 


ADDRESS DESCRIPTOR INDEX field 


The ADDRESS DESCRIPTOR INDEX field specifies the index of the first address descriptor (see 3.3.5.1) in the defect list that the device server 
shall return. If the ADDRESS DESCRIPTOR INDEX field is set to: 


a) a value less than the number of available address descriptors, then the device server shall transfer a defect list beginning with the 
address descriptor that is at the ADDRESS DESCRIPTOR INDEX field value multiplied by the size of the address descriptor; or 


b) a value greater than or equal to the number of available address descriptors, then the device server shall return a zero 
length defect list. 


ALLOCATION LENGTH field 


The ALLOCATION LENGTH field is defined in SPC-5. The application client is responsible for comparing the allocation length requested in the 
CDB with the DEFECT LIST LENGTH field value returned in the parameter data to determine whether a partial list was received. If the length of 
all the address descriptors that are available is greater than FFFF_FFFFh, then the device server shall transfer the length of address descriptors 
specified by the allocation length or the DEFECT LIST LENGTH field value plus eight, whichever is less, and complete the command with GOOD 
status. 
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3.25.2 READ DEFECT DATA (12) parameter data 
The READ DEFECT DATA (12) parameter data (see table 129) contains an eight byte header, followed by zero or more address descriptors. 


Table 129 READ DEFECT DATA (12) parameter data 
































Bit 7 6 5 4 3 2 1 0 
Byte 

0 Reserved 

1 Reserved PLISTV GLISTV DEFECT LIST FORMAT 

2 Reserved 

3 Reserved 

4 (MSB) 

ea DEFECT LIST LENGTH (N - 7) 

7 (ss) | 

Defect List (if any) 
8 





Address descriptor‘(s) (if any) 





n 














See the READ DEFECT DATA (10) command (see 3.24.2) for the definitions of the fields in the defect list header that are not 
described in this clause. 


DEFECT LIST LENGTH field 


The DEFECT LIST LENGTH field indicates the length in bytes of address descriptors from the beginning address descriptor 
specified by the ADDRESS DESCRIPTOR INDEX field to the last address descriptor available to be returned. A value of FFFF_FFFFh 
in the DEFECT LIST LENGTH field indicates that more than FFFF_FFFEh bytes are available. 
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3.26 


READ LONG (10) command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


The READ LONG (10) command (see table 130) requests that the device server transfer data from a single logical block to the 
data-in buffer. The data transferred during the READ LONG (10) command is vendor-specific, but shall include the following 
items recorded on the medium: 


a) 


if a logical block is being transferred, then: 
A) _ user data or transformed user data for the logical block; 
B) protection information or transformed protection information, if any, for the logical block; and 


©) any additional information (e.g., ECC bytes) for all the physical blocks in the logical block. 
or 


if a physical block is being transferred, then: 

A) _ user data or transformed user data for all the logical blocks in the physical block; 

B) protection information or transformed protection information, if any, for all the logical blocks in the physical block; and 
©) any additional information (e.g., ECC bytes). 


If a cache contains a more recent version of a logical block, the device server shall write the logical block to the medium before 
reading it. The values in the Read-Write Error Recovery mode page (see 5.3.22) do not apply to this command. The device server 
may perform retries while processing this command. 


Table 130 READ LONG (10) command 



































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (3Eh) 

1 Reserved PBLOCK CORRCT Obsolete 
2 (MSB) 
Se%e LOGICAL BLOCK ADDRESS 

5 (LSB) 
6 Reserved 

: wee) BYTE TRANSFER LENGTH 

8 (LSB) 
9 CONTROL 
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LOGICAL BLOCK ADDRESS field 
See 2.2.3 for the definition of the LOGICAL BLOCK ADDRESS field. 


PBLOCK bit 


If there is more than one logical block per physical block (i.e., the LOGICAL BLOCKS PER PHYSICAL BLOCK EXPONENT field in the READ CAPAC- 
ITY (16) data is set to a non-zero value), then the device server shall support the physical block (PBLOCK) bit. 


1 a PBLOCK bit set to one specifies that the device server shall return the entire physical block containing the specified logical block, and 
O aPBLOCK bit set to zero specifies that the device server shall return bytes representing only the specified logical block. 


If there are one or more physical blocks per logical block (i.e., the LOGICAL BLOCKS PER PHYSICAL BLOCK EXPONENT field in the READ CAPAC- 
ITY (16) data is set to zero) and the PBLOCK bit is set to one, then the device server shall return CHECK CONDITION status with the sense key set 
to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 


CORRCT (correct) bit 


0 = Acorrect (CORRCT) bit set to zero specifies that a logical block be read without any correction made by the device server. A CORRCT bit 
set to zero should result in GOOD status unless data is not transferred for some reason other than that the data is non-correctable. In this 
case the appropriate status and sense data shall be returned. 


1 A CORRCT bit set to one specifies that the data be corrected by ECC before being transferred to the data-in buffer. 


BYTE TRANSFER LENGTH field 


The BYTE TRANSFER LENGTH field specifies the number of bytes of data that shall be read from the specified logical block and transferred to 
the data-in buffer. If the BYTE TRANSFER LENGTH field is not set to zero and does not match the available data length, the device server shall 
terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
INVALID FIELD IN CDB. In the sense data (see SPC-5), the VALID and ILI bits shall each be set to one and the INFORMATION field shall be set to 
the difference (i.e., residue) of the requested byte transfer length minus the actual available data length in bytes. Negative values shall be indi- 
cated by two's complement notation. 


A BYTE TRANSFER LENGTH field set to zero specifies that no bytes shall be read. This condition shall not be considered an error. 
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3.27 


Direct Access Block commands (SPC-5 and SBC-4) 


READ LONG (16) command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


The READ LONG (16) command (see table 131) requests that the device server transfer data from a single logical block to the 
data-in buffer. The data transferred during the READ LONG (16) command is vendor-specific, but shall include the following 
items recorded on the medium: 


a) 


if a logical block is being transferred, then: 

A) _ user data or transformed user data for the logical block; 

B) protection information or transformed protection information, if any, for the logical block; and 

©) any additional information (e.g., ECC bytes) for all the physical blocks in the logical block. 

or 

if a physical block is being transferred, then: 

A) _ user data or transformed user data for all the logical blocks in the physical block; 

B) protection information or transformed protection information, if any, for all the logical blocks in the physical block; and 
©) any additional information (e.g., ECC bytes). 


If a cache contains a more recent version of a logical block, the device server shall write the logical block to the medium before 
reading it. The values in the Read-Write Error Recovery mode page (see 5.3.22) do not apply to this command. The device server 
may perform retries while processing this command. This command is implemented as a service action of the SERVICE ACTION 
IN operation code. 


Table 131 READ LONG (16) command 
































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (9Eh) 
Reserved SERVICE ACTION (11h) 
(MSB) 

- LOGICAL BLOCK ADDRESS 

9 (LSB) 
10 

Reserved 
11 
12 (MSB) 
BYTE TRANSFER LENGTH 

13 (LSB) 
14 Reserved PBLOCK CORRCT 
15 CONTROL 











See the READ LONG (10) command (see 3.26) for the definitions of the fields in this command. 
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3.28 REASSIGN BLOCKS command 


3.28.1 REASSIGN BLOCKS command overview 


The REASSIGN BLOCKS command (see table 132) requests that the device server reassign defective logical blocks to another area 
on the medium set aside for this purpose. The device server should also record the location of the defective logical blocks in the 
GLIST, if supported. This command shall not alter the contents of the PLIST. 


The parameter list provided in the data-out buffer contains a defective LBA list that contains the LBAs of the logical blocks to be 
reassigned. The device server shall reassign the parts of the medium used for each logical block in the defective LBA list. More 
than one physical block may be relocated by each LBA. If the device server is able to recover user data and protection 
information, if any, from the original logical block, it shall write the recovered user data and any protection information to the 
reassigned logical block. If the LBA is unmapped, then the device server shall cause the LBA to become mapped and write the 
data that was retrieved during a read operation specifying the LBA that was reassigned to the logical block (see SBC-4). If the 
device server is unable to recover user data and protection information, if any, it shall write vendor-specific data as the user data 
and shall write a default value of FFFFFFFF_FFFFFFFFh as the protection information, if enabled. The data in all other logical 
blocks on the medium shall be preserved. 


NOTE _ The effect of specifying a logical block to be reassigned that previously has been reassigned is to 
reassign the logical block again. Although not likely, over the life of the medium, a logical block may 
be assigned to multiple physical block addresses until no more spare locations remain on the 
medium. 


Table 132 REASSIGN BLOCKS command 





Bit 7 6 5 4 3 2 1 0 
Byte 


0 OPERATION CODE (07h) 




















1 Reserved LONGLBA LONGLIST 
2 











Reserved 





4 











5 CONTROL 








LONGLBA (Long LBA) bit 
0 = Along LBA (LONGLBA) bit set to zero specifies that the REASSIGN BLOCKS defective LBA list contains four byte LBAs. 
1 A LONGLBA bit set to one specifies that the REASSIGN BLOCKS defective LBA list contains eight byte LBAs. 
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3.28.2 REASSIGN BLOCKS parameter list 


The REASSIGN BLOCKS parameter list (see table 133) contains a four-byte parameter list header followed by a defective LBA list 
containing one or more LBAs. 


Table 133. REASSIGN BLOCKS parameter list 





Bit 7 6 5 4 3 2 1 0 
Byte 


























0 





Parameter list header (see table 134 or table 135) 








DEFECTIVE LBA LIST (if any) 














n 





LONGLIST bit 
0 If LONGLIST is set to zero, the parameter list header is defined in table 134. 


Table 134 REASSIGN BLOCKS short parameter list header 






































Bit 7 6 5 4 3 2 1 0 
Byte 
0 
Reserved 
1 
2 (MSB) 
DEFECT LIST LENGTH 
3 (LSB) 














1 If LONGLIST is set to one, the parameter list header is defined in table 135. 


Table 135 REASSIGN BLOCKS long parameter list header 

















Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
DEFECT LIST LENGTH 
3 (LSB) 








DEFECT LIST LENGTH field 


The DEFECT LIST LENGTH field indicates the total length in bytes of the DEFECTIVE LBA LIST field. The DEFECT LIST LENGTH field does not include 
the parameter list header length and is equal to either: 


a) four times the number of LBAs, if the LONGLBA bit is set to zero; or 
b) eight times the number of LBAs, if the LONGLBA bit is set to one. 
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DEFECTIVE LBA LIST field 


The DEFECTIVE LBA LIST field contains a list of defective LBAs. Each LBA is a four-byte field if the LONGLBA bit is set to zero or an eight-byte field 
if the LONGLBA bit is set to one. The LBAs shall be in ascending order. 


If the direct-access block device has insufficient capacity to reassign all of the specified logical blocks, the device server shall 
terminate the command with CHECK CONDITION status with the sense key set to HARDWARE ERROR and the additional sense 
code set to NO DEFECT SPARE LOCATION AVAILABLE. 


If the direct-access block device is unable to successfully complete a REASSIGN BLOCKS command, the device server shall 
terminate the command with CHECK CONDITION status with the appropriate sense data (see SPC-5). The first LBA not reassigned 
shall be returned in the COMMAND-SPECIFIC INFORMATION field of the sense data. If information about the first LBA not 
reassigned is not available, or if all the defects have been reassigned, the COMMAND-SPECIFIC INFORMATION field shall be set to 
FFFFFFFFh if fixed format sense data is being used or FFFFFFFF_FFFFFFFFh if descriptor format sense data is being used. 


If the REASSIGN BLOCKS command failed due to an unexpected unrecoverable read error that would cause the loss of data in a 
logical block not specified in the defective LBA list, the LBA of the unrecoverable block shall be returned in the INFORMATION 
field of the sense data and the VALID bit shall be set to one. 


If the REASSIGN BLOCKS command returns CHECK CONDITION status and the sense data COMMAND-SPECIFIC INFORMATION field contains a 
valid LBA, the application client should remove all LBAs from the defective LBA list prior to the one returned in the COMMAND-SPECIFIC INFOR- 
MATION field. If the sense key is MEDIUM ERROR and the INFORMATION field contains the valid LBA, the application client should insert that 
new defective LBA into the defective LBA list and reissue the REASSIGN BLOCKS command with the new defective LBA list. Otherwise, the 
application client should perform any corrective action indicated by the sense data and then reissue the REASSIGN BLOCKS command with the 
new defective LBA list. 
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3.29 


RECEIVE DIAGNOSTIC RESULTS command 


The RECEIVE DIAGNOSTIC RESULTS command (see table 136) requests analysis data be sent to the application client Data-In 
Buffer after completion of a SEND DIAGNOSTIC command (see 3.46), or, optionally, SCSI-3 Enclosure Services (SES) pages be sent 
to the initiator. Support for SES is indicated in the drive product manual. 


If no data in the optional Page format was requested by the SEND DIAGNOSTIC command (0 in bit 4 of Table 187), the data 
returned to the initiator is in the format shown in Table 137. 


All FRU and error code definitions are unique to the product and intended for factory/field maintenance personnel. 


Table 136 RECEIVE DIAGNOSTIC RESULTS command 












































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (1Ch) 

1 Reserved PCV 

2 PAGE CODE 

3 (MSB) 

ALLOCATION LENGTH 
4 (LSB) 
5 CONTROL 








PCV (Page Code Valid) bit 


0 


A page code valid (PCV) bit set to zero specifies that the device server return parameter data based on the most recent SEND DIAGNOS- 

TIC command (e.g., the diagnostic page with the same page code as that specified in the most recent SEND DIAGNOSTIC command). 

The response to a RECEIVE DIAGNOSTIC RESULTS command with the PCV bit set to zero is vendor-specific if: 

a) The most recent SEND DIAGNOSTIC command was not a SEND DIAGNOSTIC command defining parameter data to return; 

b) A RECEIVE DIAGNOSTIC RESULTS command with a PCV bit set to one has been processed since the last SEND DIAGNOSTIC command 
was processed; or 


c) No SEND DIAGNOSTIC command defining parameter data to return has been processed since power on, hard reset, or logical unit 
reset. 


A page code valid (PCV) bit set to one specifies that the device server return the diagnostic page specified in the PAGE CODE field. Page 
code values are defined in Table 255. 


PAGE CODE field 


The PAGE CODE field identifies which diagnostic page is requested as a result of a RECEIVE DIAGNOSTIC RESULTS command with the PCV bit 
equal to one, or returned as a result of a RECEIVE DIAGNOSTIC RESULTS parameter data. 
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ALLOCATION LENGTH field 
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The ALLOCATION LENGTH field (see 2.2.6) shall specify the number of bytes the initiator has allocated for returned data. An ALLOCATION 
LENGTH of zero indicates that no data shall be transferred. Any other value indicates the maximum number of bytes that shall be transferred. 
The drive terminates the DATA IN phase when ALLOCATION LENGTH bytes have been transferred or when all available data has been trans- 
ferred to the initiator, whichever is less. 


Table 


137 Diagnostic Data Bytes 



































Code Byte Description 

00h 0 ADDITIONAL LENGTH (MSB) [1] 

28h 1 ADDITIONAL LENGTH (LSB) [1] 

XXh 2 FRU CODE (most probable) [2] 

XXh 3 FRU CODE [2] 

XXh 4 FRU CODE [2] 

XXh 5 FRU CODE (least probable) [2] 

XXh 6 ERROR CODE (MSB) [3] 

V.U. 7 ERROR CODE (LSB) [4] 

VU. 8thrun Additional vendor unique fault information (if any) (not available) 








[1] 


[2] 


[4] 


ADDITIONAL LENGTH. This two byte value indicates the number of additional bytes included in the diagnostic data list. 
For example, if no product unique byte (byte 7) is available, this value would be O0006h. A value of 0000h means that there 
are no additional bytes. 


A FIELD REPLACEABLE UNIT (FRU) Code is a byte that identifies an assembly that may have failed. The codes will be listed 
in probability order, with the most probable assembly listed first and the least probable listed last. A code of 00h indicates 
there is no FRU information and a code of 01h indicates the entire unit should be replaced. Seagate drives return 00h in 


these bytes. 


The ERROR CODE is a two byte value that provides information designating which part of a diagnostic operation has 
failed. The LSB of the error code is vendor unique and defined in note [4]. Usually, Seagate drives support only some sub- 
set of the list given in note [4]. 


Vendor Unique codes supported by Seagate devices are listed in table 138. 
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Table 138 
Code 
Oth 
02h 
04h 
08h 
09h 
0Ch 
10h 
14h 
18h 
20h 
30h 
34h 
40h 
4th 
42h 
43h 
45h 
60h 
70h 
80h 
81h 
Cth 


Diagnostic Fault Codes 

Fault description 

Formatter Diagnostic Error 

Microprocessor RAM Diagnostic Error 

No Drive Ready 

No Sector or Index Detected 

Fatal Hardware Error While Doing Drive Diagnostics 
No Drive Command Complete 

Unable to Set Drive Sector Size 

Unable to Clear Drive Attention 

Unable to Start Spindle Motor 

Unable to Recal Drive 

Unable to Send Write Current Data to Drive 
Unable to Issue Drive SEEK Command 

Unable to Read User Table From Drive 

Ran Out of Sectors While Doing Drive Diagnostics 
Unable to Read Reallocation Table 

Unable to Read ETF Log 

Firmware Read from disk or Sent by Host has an Invalid Checksum 
Thermal Calibration Failure 

Microprocessor Internal Timer Error 

Buffer Controller Diagnostic Error 

Buffer RAM Diagnostic Error 


Data Miscompare While Doing Drive Diagnostics 
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3.30 RELEASE (6) command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


The RELEASE(6) command (see table 139) is used to release a previously reserved logical unit. This subclause describes only 
those instances where the RELEASE(6) command differs from the RELEASE(10) command. Except for the instances described in 
this subclause, the RELEASE(6) command shall function exactly like the RELEASE(10) command (see 3.31). 


Table 139 RELEASE (6) Command 












































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (17h) 

1 Reserved Obsolete 

2 Obsolete 

3 Reserved 

4 Reserved 

5 CONTROL 











The RELEASE(6) command shall not release third-party reservations. 
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3.31 RELEASE (10) command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


3.31.1 RELEASE (10) command introduction 
The RELEASE(10) command (see table 140) is used to release a previously reserved logical unit. 


Table 140 RELEASE (10) Command 
























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (57h) 
1 Reserved 3RDPTY Reserved LONGID Obsolete 
2 Obsolete 
3 THIRD-PARTY DEVICE ID 
4 Reserved 
5 Reserved 
6 Reserved 
7 (MSB) 
PARAMETER LIST LENGTH 
8 (LSB) 
9 CONTROL 














The RESERVE and RELEASE commands provide a basic mechanism for contention resolution in multiple-initiator systems. See 
5.5.1 for a general description of reservations and the commands that manage them. A reservation may only be released by a 
RELEASE command from the initiator that made it. It is not an error for an application client to attempt to release a reservation 
that is not currently valid, or is held by another initiator. In this case, the device server shall return GOOD status without altering 
any other reservation. 


Byte 1 Bit 0 and Byte 2 provide an obsolete way to release previously reserved extents within a logical unit. If Byte 1, Bit 0 is equal 
to one, device servers not implementing the obsolete capability shall terminate the command with CHECK CONDITION status 
and the sense key shall be set to ILLEGAL REQUEST. 
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3.31.2 Logical unit release 


Logical unit reservation release is mandatory if the RELEASE(10) command is implemented. This command shall cause the device 
server to terminate all non-third-party logical unit reservations that are active from the initiator to the specified logical unit. 


3.31.3 Third-party release 


Third-party reservation release is optional if the RELEASE(10) command is implemented. Third-party release allows an 
application client to release a logical unit that was previously reserved using third-party reservation. 


3RDPTY (third-party) bit 


0 If the third-party (3RDPTY) bit is zero, then a third-party release is not requested. If the 3RDPTY bit is zero then the LONGID bit and the 
PARAMETER LIST LENGTH field shall be ignored. 


1 If the 3RDPTY bit is one then the device server shall release the specified logical unit, but only if the initiator ID, 3RDPTY bit, and 
THIRD-PARTY DEVICE ID are identical when compared to the RESERVE command that established the reservation. The device server shall 


not modify the mode parameters for commands received from the third-party device even if the device server implements the transfer 
of mode parameters with a third-party RESERVE command. 


THIRD-PARTY DEVICE ID field and LONGID bit 


If the THIRD-PARTY DEVICE ID value associated with the reservation release is smaller than 255, the LONGID bit may be zero and the ID value 
sent in the CDB THIRD-PARTY DEVICE ID field. Device ID formats are protocol specific. If the LONGID bit is zero, the PARAMETER LIST LENGTH 
field shall be set to zero. If the THIRD-PARTY DEVICE ID is greater than 255, the LONGID bit shall be one. 


Device servers that support device IDs greater than 255 shall accept commands with LONGID equal to one. Device servers whose 
devices IDs are limited to 255 or smaller may reject commands with LONGID equal to one with CHECK CONDITION status and a 
sense key of ILLEGAL REQUEST. 


If the LONGID bit is one, the parameter list length shall be eight, and the parameter list shall have the format shown in table 96. If 
the LONGID bit is one, the THIRD-PARTY DEVICE ID field in the CDB shall be ignored. If the LONGID bit is one and the parameter 
list length is not eight, the device server shall return a CHECK CONDITION status with a sense key of ILLEGAL REQUEST. 


Table 141 RELEASE (10) parameter list 





Bit 7 6 5 4 3 2 1 0 
Byte 


























0 





THIRD-PARTY DEVICE ID 
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3.32 REPORT IDENTIFYING INFORMATION 


The REPORT IDENTIFYING INFORMATION command requests that the device server send device identification information to the 
application client. 


The device server shall return the same identifying information regardless of the |_T nexus being used to retrieve the identifying 
information. 


Processing a REPORT IDENTIFYING INFORMATION command may require the enabling of a nonvolatile memory within the 
logical unit. If the nonvolatile memory is not ready, the command shall be terminated with CHECK CONDITION status, rather than 
wait for the nonvolatile memory to become ready. The sense key shall be set to NOT READY and the additional sense code shall 
be set as described in table 203. This information should allow the application client to determine the action required to cause 
the device server to become ready. 


Table 142 REPORT IDENTIFYING INFORMATION command 





















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (A3h) 
1 Reserved SERVICE ACTION (05h) 
2 
Reserved 
3 
4 
RESTRICTED (see SCC-2) 
5 
6 (MSB) 
ALLOCATION LENGTH 
9 (LSB) 
10 INFORMATION TYPE Reserved 
11 CONTROL 














ALLOCATION LENGTH field 
The ALLOCATION LENGTH field is defined in 2.2.6. 
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INFORMATION TYPE field 
The INFORMATION TYPE field (see table 143) specifies the type of information to be reported. 


Table 143. INFORMATION TYPE 























Code Description Length Reference 
0000000b Peripheral device identifying information Oto 64bytes | Table 33 
0000010b Peripheral device text identifying information. 65 to 512bytes | Table 33 
1111111b Identifying information supported. The parameter data contains a list of sup- 0 to 256 bytes | 3.32.1 

ported identifying information types and the maximum length of each. 
XXXXXX1b Restricted. SCC-2 
All other Reserved. 








The REPORT IDENTIFYING INFORMATION parameter data format used when the INFORMATION TYPE field is set to O0O0O0000b or 
000001 0b is shown in table 144. 


Table 144 REPORT IDENTIFYING INFORMATION parameter data 














Bit 7 6 5 4 3 2 1 0 
Byte 
0 
Reserved 
1 
2 (MSB) 
INFORMATION LENGTH (n - 3) 
3 (LSB) 
4 
INFORMATION 
n 














INFORMATION LENGTH 


The INFORMATION LENGTH field indicates the length in bytes of the INFORMATION field. The relationship between the INFORMATION LENGTH 
field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 


INFORMATION 
The INFORMATION field contains the identifying information that has the specified information type (see table 143). 
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3.32.1 IDENTIFYING INFORMATION SUPPORTED parameter data 


The REPORT IDENTIFYING INFORMATION parameter data format used when the INFORMATION TYPE field is set to 1111111b is 
shown in table 145. 


Table 145 REPORT IDENTIFYING INFORMATION SUPPORTED parameter data 














Bit 7 6 5 4 3 2 1 0 
Byte 
0 
Reserved 
1 
2 (MSB) 
IDENTIFYING INFORMATION LENGTH (n - 3) Se 
3 (LSB) 








Identifying information descriptor list 


























4 
Identifying information descriptor [first] (see table 146) 
7 
n-3 
Identifying information descriptor [last] 
n 





IDENTIFYING INFORMATION LENGTH field 

The IDENTIFYING INFORMATION LENGTH field indicates the length in bytes of the identifying information descriptor list. The relationship 
between the IDENTIFYING INFORMATION LENGTH field and the ALLOCATION LENGTH field is defined in 2.2.6. 

Identifying information descriptor list 


The Identifying information descriptor list contains an identifying information descriptor (see table 146) for each identifying information type 
supported by the device server. The identifying information descriptors shall be sorted in increasing order by information type. 


Table 146 Identifying Information descriptor 














Bit 7 6 5 4 3 2 1 0 
Byte 
0 INFORMATION TYPE Reserved 
1 Reserved 
2 (MSB) 
MAXIMUM INFORMATION LENGTH Se 
3 (LSB) 














INFORMATION TYPE field 
The INFORMATION TYPE field indicates the information type (see table 143). 


MAXIMUM LENGTH field 


The MAXIMUM LENGTH field indicates the maximum number of bytes supported for identifying information that has the indicated information 
type. 
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REPORT LUNS command 


The REPORT LUNS command (see table 147) requests that the peripheral device logical unit inventory accessible to the |_T nexus be sent to the 
application client. The logical unit inventory is a list that shall include the logical unit numbers of all logical units having a PERIPHERAL 
QUALIFIER value of 000b (see table 60). Logical unit numbers for logical units with PERIPHERAL QUALIFIER values other than 000b and 011b 
may be included in the logical unit inventory. Logical unit numbers for logical units with a PERIPHERAL QUALIFIER value of 011b shall not be 


included in the logical unit inventory. 


















































Table 147. REPORT LUNS command 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (AOh) 
1 Reserved 
2 SELECT REPORT 
3 
iia’ Reserved 
5 
6 (MSB) 
see ALLOCATION LENGTH 
9 (LSB) 
10 Reserved 
11 CONTROL 














SELECT REPORT field 
The SELECT REPORT field (see table 148) specifies the types of logical unit addresses that shall be reported. 














Table 148 SELECT REPORT field 
Code Description 
The list shall contain the logical units accessible to the |_T nexus with the following addressing methods (see 
SAM-5): 
a) Logical unit addressing method, 
00h b) Peripheral device addressing method; and 
c) Flat space addressing method. 
If there are no logical units, the LUN LIST LENGTH field shall be zero. 
Oth The list shall contain only well known logical units, if any. If there are no well known logical units, the LUN LIST 
LENGTH field shall be zero. 
02h The list shall contain all logical units accessible to the |_T nexus. 
03h -FFh Reserved 














ALLOCATION LENGTH field 
The ALLOCATION LENGTH field is defined in 2.2.6. The allocation length should be at least 16. 


The REPORT LUNS command shall return CHECK CONDITION status only when the device server is unable to return the 
requested report of the logical unit inventory. 


If a REPORT LUNS command is received from an |_T nexus with a pending unit attention condition (i.e., before the device server 
reports CHECK CONDITION status), the device server shall perform the REPORT LUNS command (see SAM-5). 
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The REPORT LUNS parameter data should be returned even though the device server is not ready for other commands. The 
report of the logical unit inventory should be available without incurring any media access delays. If the device server is not 
ready with the logical unit inventory or if the inventory list is null for the requesting |_T nexus and the SELECT REPORT field set to 
02h, then the device server shall provide a default logical unit inventory that contains at least LUN 0 or the REPORT LUNS well 
known logical unit. A non-empty peripheral device logical unit inventory that does not contain either LUN 0 or the REPORT LUNS 
well known logical unit is valid. 


If a REPORT LUNS command is received for a logical unit that the SCSI target device does not support and the device server is not 
capable of returning the logical unit inventory, then the command shall be terminated with CHECK CONDITION status, with the 
sense key set to ILLEGAL REQUEST, and the additional sense code set to LOGICAL UNIT NOT SUPPORTED. 


The device server shall report those devices in the logical unit inventory using the format shown in table 149. 


Table 149 REPORT LUNS parameter data format 






































Bit 7 6 5 4 3 2 1 oO 
Byte 
0 (MSB) 
LUN LIST LENGTH (N-7) 
3 (LSB) 
4 
Reserved 
7 
LUN list 
8 
LUN [first] 
15 
n-7 
LUN [last] 
n 














LUN LIST LENGTH field 


The LUN LIST LENGTH field shall contain the length in bytes of the LUN list that is available to be transferred. The LUN list length is the number 
of logical unit numbers in the logical unit inventory multiplied by eight. The relationship between the LUN LIST LENGTH field and the ALLOCA- 


TION LENGTH field is defined in 2.2.6. 
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3.34 REPORT SUPPORTED OPERATION CODES command 


3.34.1 REPORT SUPPORTED OPERATION CODES command overview 


The REPORT SUPPORTED OPERATION CODES command (see table 150) requests the device server to return information on commands the 
addressed logical unit supports. This command uses the MAINTENANCE IN CDB format (see SPC-5). An application client may request a list of 
all operation codes and service actions supported by the logical unit or the command support data for a specific command.a. 


Table 150 REPORT SUPPORTED OPERATION CODES command 



























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (A3h) 

1 Reserved SERVICE ACTION (0Ch) 

2 RCTD Reserved REPORTING OPTIONS 

3 REQUESTED OPERATION CODE 

4 (MSB) 

REQUESTED SERVICE ACTION 
5 (LSB) 
6 (MSB) 
ALLOCATION LENGTH 

9 (LSB) 
10 Reserved 
11 CONTROL 














OPERATION CODE field 

The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the value defined in 
table 150. 

SERVICE ACTION field 

The SERVICE ACTION field is defined in Clause 2.2.2 and shall be set as shown in table 150. 


RCTD (Return Command Timeouts Descriptor) bit 
0  ARCTD bit set to zero specifies that the command timeouts descriptor shall not be included in any parameter data returned. 


1 A RCTD bit set to one specifies that the command timeouts descriptor shall be included in each command descriptor that is returned or 
in the one-command parameter that is returned. 
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REPORTING OPTIONS field 
The REPORTING OPTIONS field specifies the information to be returned in the parameter data. 


Table 151 REPORTING OPTIONS field 








Code Descriptions Parameter Data 
Reference 
000b A list of all operation codes and service actions supported by the logical unit shall be returned in the 3.34.2 


all_commands parameter data format. The REQUESTED OPERATION CODE CDB field and REQUESTED 
SERVICE ACTION CDB field shall be ignored. 


001b The command support data for the operation code specified in the REQUESTED OPERATION CODE field | 3.34.3 
shall be returned in the one_command parameter data format. The REQUESTED SERVICE ACTION CDB 
field shall be ignored. If the REQUESTED OPERATION CODE field specifies an operation code that has 
service actions, then the command shall be terminated with CHECK CONDITION status, with the sense 
key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


010b The command support data for the operation code and service action specified in the REQUESTED 3.34.3 
OPERATION CODE CDB field and REQUESTED SERVICE ACTION CDB field shall be returned in the 
one_command parameter data format. If the REQUESTED OPERATION CODE CDB field specifies an 
operation code that does not have service actions, then the command shall be terminated with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
INVALID FIELD IN CDB. 


011b The command support data for the operation code and service action a specified in the REQUESTED 3.34.3 
OPERATION CODE field and REQUESTED SERVICE ACTION field shall be returned in the one_command 
parameter data format. 

If: 

a) the operation code specified by the REQUESTED OPERATION CODE field specifies an operation code 
for which the device server does not implement service actions, the REQUESTED SERVICE ACTION field 
is set to 00h, and the command is supported; or 

b) the operation code specified by the REQUESTED OPERATION CODE field specifies an operation code 
for which the device server implements service actions and the value in the REQUESTED SERVICE 
ACTION field is supported, 

then the command support data shall indicate that the command is supported (i.e., the SUPPORT field 
(see table 241) is set to 011b or 101b). Otherwise, the command support data shall indicate that the 
command is not supported (i.e., the SUPPORT field is set to 001b). 


100b-111b Reserved. 























REQUESTED OPERATION CODE field 

The REQUESTED OPERATION CODE field specifies the operation code of the command to be returned in the one_command parameter data for- 
mat (see 3.34.3). 

REQUESTED SERVICE ACTION field 

The REQUESTED SERVICE ACTION field specifies the service action of the command to be returned in the one_command parameter data for- 
mat. 

ALLOCATION LENGTH field 

The ALLOCATION LENGTH field is defined in 2.2.6. 
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3.34.2 All_commands parameter data format 


The REPORT SUPPORTED OPERATION CODES all_commands parameter data format begins with a four-byte header that contains 
the length in bytes of the parameter data followed by a list of supported commands. Each command descriptor contains 
information about a single supported command CDB (i.e., one operation code and service action combination, or one 
non-service-action operation code). The list of command descriptors shall contain all commands supported by the logical unit. 


Table 152 All_commands parameter data 





















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
COMMAND DATA LENGTH (n - 3) 
3 (LSB) 
Command descriptors 

4 

Command descriptor [first] 

Command descriptor [last] (see table 153) 

n 








COMMAND DATA LENGTH field 


The COMMAND DATA LENGTH field indicates the length in bytes of the command descriptor list. The contents of the COMMAND DATA LENGTH 


field are not altered based on the allocation length 


Each command descriptor (see table 153) contains information about a single supported command CDB. 


Table 153 Command descriptor format 
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Byte 
0 OPERATION CODE 
1 Reserved 
2 (MSB) 
SERVICE ACTION 
3 (LSB) 
4 Reserved 
5 Reserved CTDP SERVACTV 
6 (MSB) 
CDB LENGTH 
7 (LSB) 
8 
Command timeouts descriptor, if any (see table 157) 
19 
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OPERATION CODE field 

The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the value defined in 
table 153. 

SERVICE ACTION field 

The SERVICE ACTION field contains a supported service action of the supported operation code indicated by the OPERATION CODE field. If the 
operation code indicated in the OPERATION CODE field does not have a service action, the SERVICE ACTION field shall be set to 00h. 
Command Duration Limit Page (CDLP) field 

The Command Duration Limit Page (CDLP) field (see table 154) indicates the mode page, if any, that specifies the command duration limit for 


the command. 


Table 154 CDLP field 





Code Description 





00b No command duration limit mode page is indicated for this command 
01b2 Command Duration Limit A mode page 
10b? Command Duration Limit B mode page 


11b Reserved 





a If this value is returned, the Command Duration Limit A mode page (see 5.3.10) shall be supported. 
b If this value is returned, the Command Duration Limit B mode page (see 5.3.11) shall be supported. 








CTDP (Command Timeouts Descriptor Present) bit 
0  ACTDP bit set to zero indicates that the command timeouts descriptor is not included in this command descriptor. 


1 A CTDP bit set to one indicates that the command timeouts descriptor is included in this command descriptor. 


SERVACTV (Service Action Valid) bit 


0 A service action valid (SERVACTV) bit set to zero indicates the operation code indicated by the OPERATION CODE field does not have ser- 
vice actions and the SERVICE ACTION field contents are reserved. 


1 A SERVACTV bit set to one indicates the operation code indicated by the OPERATION CODE field has service actions and the contents of 
the SERVICE ACTION field are valid. 


CDB LENGTH field 


The CDB LENGTH field contains the length of the command CDB in bytes for the operation code indicated in the OPERATION CODE field. If the 
SERVACTV bit is set to one, the CDB LENGTH field contains the length in bytes of the command CDB for the OPERATION CODE/ SERVICE ACTION 
combination. 


RCTD (Report Command Timeout Descriptor) bit 
0 If the RCTD bit is set to zero, the command timeouts descriptor shall not be included. 
1 If the RCTD bit is set to one in the REPORT SUPPORTED OPERATION CODES CDB, the command timeouts descriptor shall be included. 
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3.34.3 One_command parameter data format 


The REPORT SUPPORTED OPERATION CODES one_command parameter data format contains information about the CDB and a 
usage map for bits in the CDB for the command specified by the REPORTING OPTIONS, REQUESTED OPERATION CODE, and 
REQUESTED SERVICE ACTION fields in the REPORT SUPPORTED OPERATION CODES CDB. 


Table 155 One_command parameter data 









































Bit 7 6 5 4 3 2 1 0 
Byte 
0 Reserved 
1 CTDP Reserved SUPPORT 
2 (MSB) 
CDB SIZE (n - 3) ae 
3 (LSB) 
4 





CDB USAGE DATA 








n+1 





Command timeouts descriptor, if any (see table 157) 





n+12 














CTDP (Command Timeout Descriptor Present) bit 
O  ACTDP bit set to zero indicates that the command timeouts descriptor is not included in the parameter data. 


1 A CTDP bit set to one indicates that the command timeouts descriptor is included in the parameter data. 


Command Duration Limit Page (CDLP) field 

The Command Duration Limit Page (CDLP) field (see table 147) indicates the mode page, if any, that specifies the command duration limit for 
the command. 

SUPPORT field 


The SUPPORT field is defined in Table 156. 
Table 156 Support field 





Support Description 





000b Data about the requested SCSI command is not currently available. 
All data after byte 1 is not valid. A subsequent request for command support data may be successful. 








001b The device server does not support the requested command. All data after byte 1 is undefined. 
010b Reserved. 
011b The device server supports the requested command in conformance with a SCSI standard. 


The parameter data format conforms to the definition in table 155. 





100b Reserved. 





101b The device server supports the requested command in a vendor specific manner. 
The parameter data format conforms to the definition in table 155. 


110b-111b | Reserved. 
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CDB SIZE field 


The CDB SIZE field contains the size of the CDB USAGE DATA field in the parameter data, and the number of bytes in the CDB for command 
being queried (i.e., the command specified by the REPORTING OPTIONS, REQUESTED OPERATION CODE, and REQUESTED SERVICE ACTION 
fields in the REPORT SUPPORTED OPERATION CODES CDB). 


CDB USAGE DATA field 


The CDB USAGE DATA field contains information about the CDB for the command being queried. The first byte of the CDB USAGE DATA field 
shall contain the operation code for the command being queried. If the command being queried contains a service action, then that service 
action code shall be placed in the CDB USAGE DATA field in the same location as the SERVICE ACTION field of the command CDB. All other 
bytes of the CDB USAGE DATA field shall contain a usage map for bits in the CDB for the command being queried. 


The bits in the usage map shall have a one-for-one correspondence to the CDB for the command being queried. If the device server evaluated 
a bit in the CDB for the command being queried, the usage map shall contain a one in the corresponding bit position. If any bit representing 
part of a field is returned as one, all bits for the field shall be returned as one. If the device server ignores or treats as reserved a bit in the CDB for 
the command being queried, the usage map shall contain a zero in the corresponding bit position. The usage map bits for a given CDB field all 
shall have the same value. 


For example, the CDB usage bit map for the REPORT SUPPORTED OPERATION CODES command is: A3h, 0Ch, 87h, FFh, FFh, FFh, FFh, FFh, FFh, 
FFh, 00h, 07h. This example assumes that the logical unit only supports the low-order three bits of the CDB CONTROL byte. The first byte con- 
tains the operation code, and the second byte contains three reserved bits and the service action. The remaining bytes contain the usage map. 


RCTD (Report Command Timeout Descriptor) bit 
0 If the RCTD bit is set to zero, the command timeouts descriptor shall not be included. 
1 If the RCTD bit is set to one in the REPORT SUPPORTED OPERATION CODES CDB, the command timeouts descriptor shall be included. 
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3.34.4 Command timeouts descriptor 


3.34.4.1 Overview 


The command timeouts descriptor (see table 157) returns timeout information for commands supported by the logical unit 
based on the time from the start of processing for the command to its reported completion. 


Values returned in the command timeouts descriptor do not include times that are outside the control of the device server (e.g., 
prior commands with the IMMED bit set to one in the CDB, concurrent commands from the same or different I_T nexuses, 
manual unloads, power-on self tests, prior aborted commands, commands that force cache synchronization, delays in the 
service delivery subsystem). 


For commands that cause a change in power condition, values returned in the command timeouts descriptor do not include the 
power condition transition time (e.g., the time to spinup rotating media). 


Values returned in the command timeouts descriptor should not be used to compare products. 


Table 157 Command timeouts descriptor format 
























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
DESCRIPTOR LENGTH (000Ah) -_—. =| 
1 (LSB) 
2 Reserved 
3 COMMAND SPECIFIC 
4 (MSB) 
NOMINAL COMMAND PROCESSING TIMEOUT 
7 (LSB) 
8 (MSB) 
RECOMMEND COMMAND TIMEOUT 
11 (LSB) 














DESCRIPTOR LENGTH field 
The DESCRIPTOR LENGTH field indicates the number of bytes that follow in the command timeouts descriptor. 


COMMAND SPECIFIC field 


The COMMAND SPECIFIC field contains timeout information (see table 158) that is specific to one or more commands. If no command specific 
timeout information is defined by this or the applicable command standard the COMMAND SPECIFIC field is reserved. 


Table 158 Command timeout descriptor COMMAND SPECIFIC field usage in this manual 





Command Reference 





WRITE BUFFER 3.34.4.2 
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NOMINAL COMMAND PROCESSING TIMEOUT field 


A non-zero value in the NOMINAL COMMAND PROCESSING TIMEOUT field indicates the minimum amount of time in seconds the application 
client should wait prior to querying for the progress of the command identified by the parameter data that contains this command timeouts 
descriptor. A value of zero in the NOMINAL COMMAND PROCESSING TIMEOUT field indicates that no timeout is indicated. 


NOTE The value contained in the NOMINAL COMMAND PROCESSING TIMEOUT field may include time 
required for typical device error recovery procedures expected to occur on a regular basis. 
RECOMMENDED COMMAND TIMEOUT field 


A non-zero value in the RRCOMMENDED COMMAND TIMEOUT field specifies the recommended time in seconds the application client should 
wait prior to timing out the command identified by the parameter data that contains this command timeouts descriptor. A value of zero in the 
RECOMMENDED COMMAND TIMEOUT field indicates that no time is indicated. 


The device server should set the recommended command timeout to a value greater than or equal to the nominal command processing time- 
out. 


3.34.4.2. WRITE BUFFER command timeouts descriptor COMMAND SPECIFIC field usage 
For the WRITE BUFFER command, the COMMAND SPECIFIC field usage is reserved for all modes except the following: 


mg 


) Download microcode mode (04h); 


b) Download microcode and save mode (05h); 

c) Download microcode with offsets mode (06h); 

d) Download microcode with offsets and save mode (07h); 

e) Download microcode with offsets and defer activation mode (OEh) only if the microcode is activated by an event other 


than an activate deferred microcode mode; and 
f) Activate deferred microcode mode (OFh). 
If the command timeouts descriptor describes one of the WRITE BUFFER modes listed in this subclause, then the COMMAND 
SPECIFIC field indicates the maximum time, in one second increments, that access to the SCSI device is limited or not possible 


through any SCSI ports associated with a logical unit that processes a WRITE BUFFER command that specifies one of the named 
modes. A value of zero in the COMMAND SPECIFIC field indicates that the no maximum time is indicated. 
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3.35 REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS commands 


The REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS command (see table 159) requests the device server to return on task 
management functions (see SAM-5) the addressed logical unit supports. This command uses the MAINTENANCE IN CDB format 


(see SPC-5). 
Table 159 REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS command 
























































Bit 7 6 5 4 3 2 1 oO 
Byte 
0 OPERATION CODE (A3h) 
1 Reserved SERVICE ACTION (ODh) 
2 REPD 
Reserved 
5 
6 (MSB) 
ALLOCATION LENGTH (4h or larger) 
9 (LSB) 
10 Reserved 
11 CONTROL 














OPERATION CODE field 
The OPERATION CODE field shall be set as shown in table 159 for the REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS command. 


SERVICE ACTION field 
The SERVICE ACTION field shall be set as shown in table 159 for the REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS command. 


REPD bit 
1 A return extended parameter data (REPD) bit set to one specifies that the task management timeout information shall be included in the 
parameter data that is returned. 
O — _AREPD bit set to zero specifies that the task management timeout information shall not be returned. 
The format of the parameter data for the REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS command depends on the value 
of the REPD bit as follows: 
0 if the REPD bit is set to zero, the REPORT SUPPORTED TASK MANAGEMENT FUNCTION parameter data returned is shown in table 160; 


and 
1 if the REPD bit is set to one, the REPORT SUPPORTED TASK MANAGEMENT FUNCTION parameter data returned is shown in table 161. 


ALLOCATION LENGTH field 
The ALLOCATION LENGTH field is defined in 2.2.6. The allocation length should be at least four. 


CONTROL byte 
The CONTROL byte is defined in Clause 2.2.7. 
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The REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS basic parameter data format is shown in table 160. 






































Table 160 REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS parameter data 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 ATS ATSS CACAS CTSS LURS QTS Obsolete Obsolete 
1 Reserved QAES QTSS ITNRS 
2 Reserved 
3 REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS ADDITIONAL DATA LENGTH (00h) 














The REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS extended parameter data format is shown in Table 161. 

































































Table 161 REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS extended parameter data 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 ATS ATSS CACAS CTSS LURS QTS Obsolete Obsolete 
1 Reserved QAES QTSS ITNRS 
2 Reserved 
3 REPORT SUPPORTED TASK MANAGEMENT FUNCTIONS ADDITIONAL DATA LENGTH (0Ch) 
4 Reserved TMFTMOV 
5 Reserved 
6 ATS ATSTS CACATS CTSTS LURTS QTTS Reserved Reserved 
7 Reserved QAETS QTSTS ITNRTS 
8 (MSB) 
sieve TASK MANAGEMENT FUNCTIONS LONG TIMEOUT 
11 (LSB) 
12 (MSB) 
coe TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT 
15 (LSB) 














ATS (ABORT TASK Supported) bit 
1 An ATS bit set to one indicates the ABORT TASK task management functions (see SAM-5) is supported by the logical unit 


0 AnATS bit set to zero indicates the ABORT TASK task management function is not supported. 


ATSS (ABORT TASK Set Supported) bit 


1 ATS bit set to one indicates the ABORT TASK SET task management function (see SAM-5) is supported by the logical unit. 
0 ATS bit set to zero indicates the ABORT TASK SET task management function is not supported. 


CACAS (CLEAR ACA Supported) bit 
1 A CACAS bit set to one indicates the CLEAR ACA task management function (see SAM-5) is supported by the logical unit. 


0 ACACAS bit set to zero indicates the CLEAR ACA task management function is not supported. 


CTSS (CLEAR TASK SET Supported) bit 


1 A CTSS bit set to one indicates the CLEAR TASK SET task management function (see SAM-5) is supported by the logical unit. 


0 = ACTSS bit set to zero indicates the CLEAR TASK SET task management function is not supported. 


LURS (LOGICAL UNIT RESET Supported) bit 


1 A LURS bit set to one indicates the LOGICAL UNIT RESET task management function (see SAM-5) is supported by the logical unit. 


0  ALURS bit set to zero indicates the LOGICAL UNIT RESET task management function is not supported. 
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QTS (QUERY TASK Supported) bit 
1 A OTS bit set to one indicates the QUERY TASK task management function (see SAM-5) is supported by the logical unit. 
0 = AQTS bit set to zero indicates the QUERY TASK task management function is not supported. 


TRS (TARGET RESET Supported) bit 
1 ATRS bit set to one indicates the TARGET RESET task management function (See SAM-2) is supported by the logical unit. 
0 — _ATRS bit set to zero indicates the TARGET RESET task management function is not supported. 


WAKES (WAKEUP Supported) bit 
1 AWAKES bit set to one indicates the WAKEUP task management function (see SAM-2) is supported by the logical unit. 
0 AWAKES bit set to zero indicates the WAKEUP task management function is not supported. 


QAES (QUERY ASYNCHRONOUS EVENT Supported) bit 


1 A QAES bit set to one indicates the QUERY ASYNCHRONOUS EVENT task management function (see SAM-5) is supported by the logical 
unit. 


0 = AQAES bit set to zero indicates the QUERY ASYNCHRONOUS EVENT task management function is not supported. 


QTSS (QUERY TASK SET Supported) bit 


1 A QUERY TASK SET supported (QTSS) bit set to one indicates the QUERY TASK SET task management function (see SAM-5) is supported 
by the logical unit. 


0 = AQTSS bit set to zero indicates the QUERY TASK SET task management function is not supported. 


ITNRS (I-T NEXUS RESET Supported) bit 
1 An ITNRS bit set to one indicates the |_T NEXUS RESET task management function (see SAM-5) is supported by the logical unit. 
0 An ITNRS bit set to zero indicates the |_T NEXUS RESET task management function is not supported. 


TMFTMOV (Task Management Function Timeouts Valid) bit 


1 A TMFTMOV bit set to one indicates the contents of the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field and TASK MANAGE- 
MENT FUNCTIONS LONG TIMEOUT field are valid. 


0 A TMFTMOV bit set to zero indicates the contents of the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field and TASK MANAGE- 
MENT FUNCTIONS LONG TIMEOUT field are not valid and should be ignored. 


ATTS (ABORT TASK Timeout Selector) bit 


1 An ATTS bit set to one indicates that the value in the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field applies to the ABORT TASK 
task management function. 


0 AnATTS bit set to zero indicates that the value in the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field applies to the ABORT TASK 
task management function. 


ATSTS (ABORT TASK SET Timeout Selector) bit 


1 An ATSTS)bit set to one indicates that the value in the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field applies to the ABORT 
TASK SET task management function. 


0 ANnATSTS bit set to zero indicates that the value in the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field applies to the ABORT TASK 
SET task management function. 


CACATS (CLEAR ACA Timeout Selector) bit 


1 A CACATS bit set to one indicates that the value in the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field applies to the CLEAR ACA 
task management function. 


0  ACACATS bit set to zero indicates that the value in the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field applies to the CLEAR ACA 
task management function. 
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CTSTS (CLEAR TASK SET Timeout Selector) bit 
1 A CTSTS bit set to one indicates that the value in the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field applies to the CLEAR TASK 
SET task management function. 


0 = ACTSTS bit set to zero indicates that the value in the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field applies to the CLEAR TASK 
SET task management function. 


LURTS (LOGICAL UNIT RESET Timeout Selector) bit 
1 A LURTS bit set to one indicates that the value in the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field applies to the LOGICAL 
UNIT RESET task management function. 


0 —ALURTS bit set to zero indicates that the value in the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field applies to the LOGICAL UNIT 
RESET task management function. 


QTTS (QUERY TASK Timeout Selector) bit 
1 A OTTS bit set to one indicates that the value in the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field applies to the QUERY TASK 
task management function. 


0 = AQTTS bit set to zero indicates that the value in the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field applies to the QUERY TASK 
task management function. 


QAETS (QUERY ASYNCHRONOUS EVENT Timeout Selector) bit 


1 A QAETS bit set to one indicates that the value in the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field applies to the QUERY 
ASYNCHRONOUS EVENT task management function. 

0 =A QAETS bit set to zero indicates that the value in the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field applies to the QUERY ASYN- 
CHRONOUS EVENT task management function. 


QTSTS (QUERY TASK SET Timeout Selector) bit 
1 A OTSTS bit set to one indicates that the value in the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field applies to the QUERY TASK 
SET task management function. 


0 A OTSTS bit set to zero indicates that the value in the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field applies to the QUERY TASK 
SET task management function. 


ITNRTS (I_T NEXUS RESET timeout selector) bit 
1 An ITNRTS bit set to one indicates that the value in the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field applies to the |_T NEXUS 
RESET task management function. 


QO An ITNRTS bit set to zero indicates that the value in the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field applies to the |_T NEXUS 
RESET task management function. 


TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field 


If the TMFTMOV bit is set to one and the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field is not set to zero, then the contents of the TASK 
MANAGEMENT FUNCTIONS LONG TIMEOUT field indicate the recommended time in 100 millisecond increments that the application client 
should wait prior to timing out a task management function for which the applicable selector bit is set to zero. If the TMFTMOV bit is set to zero 
or the TASK MANAGEMENT FUNCTIONS LONG TIMEOUT field is set to zero, then the recommended timeout is unspecified for any task manage- 
ment function for which the applicable selector bit is set to zero. 


TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field 

If the TMFTMOV bit is set to one and the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field is not set to zero, then the contents of the 
TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field indicate the recommended time in 100 millisecond increments that the application cli- 
ent should wait prior to timing out a task management function for which the applicable selector bit is set to one. If the TAFTMOV bit is set to 
zero or the TASK MANAGEMENT FUNCTIONS SHORT TIMEOUT field is set to zero, then the recommended timeout is unspecified for any task 
management function for which the applicable selector bit is set to one. 
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3.36 REPORT TIMESTAMP command 


The REPORT TIMESTAMP command (see table 162) requests the device server to return the current value of a device clock (see 
SPC-5). This command uses the MAINTENANCE IN CDB format (see SPC-5). 


Table 162 REPORT TIMESTAMP command 
























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (A3h) 
1 Reserved SERVICE ACTION (0Fh) 
2 

Reserved 
5 
6 (MSB) 

ALLOCATION LENGTH 

9 (LSB) 
10 Reserved 
11 CONTROL 














OPERATION CODE field 
The OPERATION CODE field shall be set as shown in table 162 for the REPORT TIMESTAMP command. 


SERVICE ACTION field 
The SERVICE ACTION field shall be set as shown in table 162 for the REPORT TIMESTAMP command. 


ALLOCATION LENGTH field 
The ALLOCATION LENGTH field is defined in 2.2.6. 


CONTROL byte 
The CONTROL byte is defined in Clause 2.2.7. 
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The format for the parameter data returned by the REPORT TIMESTAMP command is shown in table 163. 


Table 163 REPORT TIMESTAMP parameter data format 
























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
TIMESTAMP PARAMETER DATA LENGTH (0Ah) S| 
1 (LSB) 
2 Reserved TIMESTAMP ORIGIN 
3 Reserved 
4 
TIMESTAMP 
9 
10 Reserved 
11 Reserved 














TIMESTAMP PARAMETER DATA LENGTH field 


The TIMESTAMP PARAMETER DATA LENGTH field indicates the number of bytes of parameter data that follow. The contents of the TIMESTAMP 
PARAMETER DATA LENGTH field are not altered based on the allocation length (see 2.2.6). 


TIMESTAMP ORIGIN field 
The TIMESTAMP ORIGIN field indicates the most recent event that initialized the returned device clock (see SPC-5). 


TIMESTAMP field 
The TIMESTAMP field contains the current value of a device clock (see SPC-5). 
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3.37 REQUEST SENSE command 


The REQUEST SENSE command (see table 164) requests that the device server transfer sense data to the application client. 


Table 164 REQUEST SENSE command 












































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (03h) 
1 Reserved DESC 
2 
Reserved 
3 
4 ALLOCATION LENGTH 
5 CONTROL 











DESC (Descriptor Format) bit 
The descriptor format (DESC) bit specifies which sense data format shall be returned. 
0 If DESC is set to zero, fixed format sense data shall be returned (see 2.4.1.2). 


1 If DESC is set to one and descriptor format sense data is supported, descriptor format sense data shall be returned (see 2.4.1.1). 


ALLOCATION LENGTH field 


The ALLOCATION LENGTH field is defined in 2.2.6. Application clients should request 252 bytes of sense data to ensure they retrieve all the 
sense data. If fewer than 252 bytes are requested, sense data may be lost since the REQUEST SENSE command with any allocation length clears 
the sense data. 


Sense data shall be available and cleared under the conditions defined in SAM-5. If the device server has no other sense data 
available to return, it shall: 


1) return the sense key set to NO SENSE, additional sense code set to NO ADDITIONAL SENSE INFORMATION and; 

2) complete the REQUEST SENSE command with GOOD status. 

3) Oncompletion of the command the logical unit shall return to the same power condition that was active before the REQUEST SENSE 
command was received. A REQUEST SENSE command shall not reset any power condition timers. 


The device server shall return CHECK CONDITION status for a REQUEST SENSE command only to report exception conditions 
specific to the REQUEST SENSE command itself. 


Examples of conditions that cause a REQUEST SENSE command to return a CHECK CONDITION status are: 


og 


) An invalid field value is detected in the CDB; 

) The device server does not support the REQUEST SENSE command (see 3.37); 
) An unrecovered error is detected by the service delivery subsystem; or 

d) Amalfunction prevents return of the sense data. 


aft 


Device servers shall return at least 18 bytes of parameter data in response to a REQUEST SENSE command if the allocation length 
is 18 or greater and the DESC bit is set to zero. Application clients may determine how much sense data has been returned by 
examining the ALLOCATION LENGTH field in the CDB and the ADDITIONAL SENSE LENGTH field in the sense data. Device servers 
shall not adjust the additional sense length to reflect truncation if the allocation length is less than the sense data available. 
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3.38 RESERVE(6) command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


The RESERVE(6) command (see table 165) is used to reserve a logical unit. This subclause describes only those instances where 
the RESERVE(6) command differs from the RESERVE(10) command. Except for the instances described in this subclause, the 
RESERVE(6) command shall function exactly like the RESERVE(10) command (see 3.39). 


Table 165 RESERVE(6) command 









































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (16h) 
1 Reserved Obsolete 
2 Obsolete 
3 
Obsolete 
4 
5 CONTROL 














Obsolete Bits 1 through 4 of Byte 1 provided a method, limited to device addresses 0 through 7, to handle third-party 


reservations in earlier versions of the SCSI standard. The obsolete method has been replaced by the RESERVE(10) and 
RELEASE(10). 


Byte 1 Bit 0 and Bytes 2 through 4 provide an obsolete way to reserve extents within a logical unit. The Seagate device server 
does not support the feature--if it is set, it will be rejected with an ILLEGAL REQUEST/INVALID BIT IN THE CDB. The Seagate device 
server ignores the Obsolete field for the Reservation ID. 
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3.39 RESERVE (10) command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


3.39.1 RESERVE (10) command introduction 
The RESERVE(10) command (see table 166) is used to reserve a logical unit. 


Table 166 RESERVE (10) Command 
























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (56h) 
1 Reserved 3RDPTY Reserved LONGID Obsolete 
2 Obsolete 
3 THIRD-PARTY DEVICE ID 
4 Reserved 
5 Reserved 
6 Reserved 
7 (MSB) 
PARAMETER LIST LENGTH 
8 (LSB) 
9 CONTROL 














The RESERVE and RELEASE commands provide a basic mechanism for contention resolution in multiple-initiator systems. The 
third-party reservation allows logical units to be reserved for another specified SCSI device. See 5.5.1 for a general description of 
reservations and the commands that manage them. 


If the RESERVE(10) command is implemented, then the RELEASE(10) also shall be implemented. 


Byte 1 Bit 0 and Byte 2 provide an obsolete way to reserve extents within a logical unit. If Byte 1, Bit 0 is equal to one, device 
servers not implementing the obsolete capability shall terminate the command with CHECK CONDITION status and the sense 
key shall be set to ILLEGAL REQUEST. 


3.39.2 Logical unit reservation 


Logical unit reservations are mandatory if the RESERVE(10) command is implemented. This command shall request that the 
entire logical unit be reserved for the exclusive use of the initiator until the reservation is superseded by another valid RESERVE 
command from the same initiator or until released by a RELEASE command from the same initiator that made the reservation, by 
a TARGET RESET task management function performed by any initiator, by a hard reset condition, or by a power on cycle. A 
logical unit reservation shall not be granted if the logical unit is reserved by another initiator. It shall be permissible for an 
initiator to reserve a logical unit that is currently reserved by that initiator. If the LONGID bit or the 3RDPTY bit is zero then the 
PARAMETER LIST LENGTH field shall be ignored. 


If the logical unit is reserved for another initiator, the device server shall return RESERVATION CONFLICT status. After honoring a 
logical unit reservation, the device server shall check each newly received command for reservation conflicts. 


For multiple port implementations, devices on other ports (i.e, the ports that do not include the initiator to which the 
reservation has been granted) also shall be denied access to the logical unit as described in the preceding clause. 
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3.39.3 Third-party reservation 


Third-party reservations are mandatory if the RESERVE(10) command is implemented. The third-party reservation for the 
RESERVE(10) command allows an application client to reserve a logical unit within a logical unit for another SCSI device. This is 
intended for use in multiple initiator systems that use the COPY or EXTENDED COPY command. 


3RDPARTY bit 
0 If the third-party (3RDPTY) bit is zero, then a third-party reservation is not requested. If the 3RDPTY bit is zero then the LONGID bit shall 
be ignored. 


1 If the 3RDPTY bit is one then the device server shall reserve the specified logical unit for the SCSI device specified in the THIRD-PARTY 
DEVICE ID field. Device ID formats are protocol specific. The device server shall preserve the reservation until it is superseded by another 
valid RESERVE command from the initiator that made the reservation or until it is released by the same initiator, by a TARGET RESET task 
management function performed by any initiator, a hard reset condition, or by a power on cycle. The device server shall ignore any 
attempt to release the reservation made by any other initiator. 


After a third-party reservation has been granted, the initiator that sent the RESERVE command shall be treated like any other 
initiator. Reservation conflicts shall occur in all cases where another initiator is not allowed access due to the reservation. 


If independent sets of mode parameters are implemented, a third-party reservation shall cause the device server to transfer the 
set of mode parameters in effect for the application client that sent the RESERVE command to the mode parameters used for 
commands from the third-party device. Any subsequent command issued by the third-party device shall be executed according 
to the mode parameters in effect for the application client that sent the RESERVE command. 


THIRD-PARTY DEVICE ID field 


If the THIRD-PARTY DEVICE ID value associated with the reservation release is smaller than 255, the LONGID bit may be zero and the ID value 
sent in the CDB. Device ID formats are protocol specific. If the THIRD-PARTY DEVICE ID is greater than 255, the LONGID bit shall be one. If the 
LONGID bit is one, the THIRD-PARTY DEVICE ID field in the CDB shall be ignored. If the LONGID bit is one, the parameter list length shall be at 
least eight. If the LONGID bit is one and the parameter list length is less than eight, the device server shall return a CHECK CONDITION status 
with a sense key of ILLEGAL REQUEST. 


Device servers that support device IDs greater than 255 shall accept commands with LONGID equal to one. Device servers whose 
devices IDs are limited to 255 or smaller may reject commands with LONGID equal to one with CHECK CONDITION status and a 
sense key of ILLEGAL REQUEST. 


If the LONGID bit is one, the parameter list length shall be eight, and the parameter list shall have the format shown in table 167. 
If the LONGID bit is one and the parameter list length is not eight, the device server shall return a CHECK CONDITION status with 
a sense key of ILLEGAL REQUEST. 


Table 167 RESERVE (10) ID only parameter list 





Bit 7 6 5 4 3 2 1 0 
Byte 


























0 





THIRD-PARTY DEVICE ID 

















3.39.4 Superseding reservations 


Superseding reservations is mandatory if the RELEASE(10) command is implemented. An application client that holds a current 
logical unit reservation may modify that reservation by issuing another RESERVE command to the same logical unit. The 
superseding RESERVE command shall release the previous reservation state when the new reservation request is granted. The 
current reservation shall not be modified if the superseding reservation request is not granted. If the superseding reservation 
cannot be granted because of conflicts with a previous reservation, other than the reservation being superseded, then the 
device server shall return RESERVATION CONFLICT status. 
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3.40 REZERO UNIT command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


Table 168 REZERO UNIT command (01h) 












































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (01h) 

1 LUN 

2 LOGICAL BLOCK ADDRESS MUST BE 0’S 

3 

4 Reserved 

5 CONTROL 














The Rezero Unit command (see table 168) requests that the disk drive set its logical block address to zero and return the disk 
drive read/write heads to the track (or cylinder) containing Logical Block Zero. This command is intended for systems which 
disable retries and the initiator performs error recovery. It is longer than a seek to Logical Block Address zero and should be 
utilized if seek errors are encountered. 


For systems that support disconnection, the disk drive disconnects when this command is received. 


A Rezero Command also causes a thermal compensation to occur and resets the thermal compensation cycle timer back to its 
start, thus allowing the host to know when to expect the next thermal compensation to occur. The host can thus prevent critical 
data transfer operations from being interrupted at an undesirable time. 


For drives that support saved log parameters, the Rezero Unit command will also save log counters to the media and reset the 
log save timer back to its start. 


LUN (Logical Unit Number) field 


Seagate drives only support Logical Unit Number 0. 


CONTROL byte 
The CONTROL byte is described in clause 2.2.7. 
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3.41 SANITIZE command 


3.41.1 SANITIZE command introduction 


The SANITIZE command (see table 169) requests that the device server perform a sanitize operation. This command shall be 
processed as if it has a HEAD OF QUEUE task attribute. 


Table 169 SANITIZE command (48h) 


















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (48h) 
1 IMMED ZNR AUSE SERVICE ACTION 
2 
Reserved 
6 
7 (MSB) 
; PARAMETER LIST LENGTH (SB) 
9 CONTROL 














OPERATION CODE field 
The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the value defined in 
Table 169. 
IMMED bit 
0 If the IMMED (immediate) bit is set to zero, then the device server shall return status after the sanitize operation is completed. 
1 If the IMMED bit set to one, then the device server shall return status as soon as the CDB and parameter data, if any, have been validated. 
The REQUEST SENSE command may be used to poll for progress of the sanitize operation regardless of the value of the IMMED bit. 
ZNR bit 


0 Fora zoned block device, a zoned no reset (ZNR) bit set to zero specifies that as part of completing a sanitize operation, the 
device server shall perform the equivalent of a RESET WRITE POINTER command (see ZBC) with the ALL bit set to one. 


1 For a zoned block device, a ZNR bit set to one specifies that as part of completing a sanitize operation, the device server: 


a) unless otherwise specified (e.g., a write pointer zone is set to offline), shall not modify the write pointer 


AUSE bit 


If the allow unrestricted sanitize exit (AUSE) bit is set to one, and the specified sanitize operation fails, then the device server shall process a 
subsequent EXIT FAILURE MODE service action as if the previous sanitize operation had completed without error (see Completing a sanitize 
operation in SBC-4). 


If: 
a) the AUSE bit is set to zero in the SANITIZE command that requested a sanitize operation; 
b) the specified sanitize operation completes with an error; and 
c) asubsequent SANITIZE command with the EXIT FAILURE MODE service action is received, 
then the device sever shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the addi- 
tional sense code set to INVALID FIELD IN PARAMETER LIST. 
SERVICE ACTION field 
The SERVICE ACTION field is defined in 2.2.2 and set to a value defined in table 170. 
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PARAMETER LIST LENGTH field 


The PARAMETER LIST LENGTH field specifies the length in bytes of the parameter data that shall be sent from the application client to the 
device server. A PARAMETER LIST LENGTH field set to zero specifies that no data shall be transferred. 


CONTROL byte 
The CONTROL byte is described in clause 2.2.7. 


3.41.2 SANITIZE service actions 


The SANITIZE command service actions are defined in (see table 170). At least one service action shall be supported if the 
SANITIZE command is supported. If the specified service action is not supported, then the command shall be terminated with 
CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and additional sense code set to INVALID FIELD IN CDB. 


Table 170 SANITIZE service action codes 




















nolan PARAMETER LIST LENGTH 

Code Name Description field requirement [1][1] Reference 

oth OVERWRITE Perform the overwrite Greater than 0004h and less 3.41.3 
sanitize method. than logical block length + 5 

o2h BLOCK ERASE Perform the block erase Set to 0000h 3.41.4 
sanitize method. 

03h CRYPTOGRAPHIC Perform the cryptographic Set to 0000h 3.41.5 

ERASE erase sanitize method. 
1Fh EXIT FAILURE MODE Exit the Sanitize failure mode Set to 0000h 3.45.6 
allothers | Reserved 

















[1] If the requirement is not met, then the SANITIZE command is terminated with CHECK CONDITION status 
with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 
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SANITIZE command with OVERWRITE service action 


3.41.3.2 


3.41.3.1 OVERWRITE service action introduction 


The OVERWRITE service action (see table 170) performs a sanitize operation using the overwrite method (see SBC-4). 


OVERWRITE service action parameter list 
The parameter list format for the OVERWRITE service action is shown in Table 171. 



























































Table 171 OVERWRITE service action parameter list 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 INVERT TEST OVERWRITE COUNT 
1 Reserved 
2 (MSB) 
INITIALIZATION PATTERN LENGTH (n - 3) 
3 (LSB) 
4 
INITIALIZATION PATTERN 
n 
INVERT bit 


1 The INVERT MULT PASSES bit set to one specifies that the initialization pattern and protection information bytes, if any, shall be inverted 
(i.e., each bit XORed with one) between consecutive overwrite passes. 


0 ‘The INVERT MULT PASSES bit set to zero specifies that the initialization pattern and protection information bytes, if any, are written as 
specified in the INITIALIZATION PATTERN field on each overwrite pass. 
TEST field 
The TEST field is described in Table 172. 











Table 172 ‘TEST field 
Code Description 
00b Shall not cause any changes in the defined behavior of the SANITIZE command 
01b to 11b Vendor specific 








OVERWRITE COUNT field 
The OVERWRITE COUNT field specifies the number of overwrite passes to be performed. A value of 00h is reserved. 


INITIALIZATION PATTERN LENGTH field 


The INITIALIZATION PATTERN LENGTH field specifies the length in bytes of the INITIALIZATION PATTERN field. The INITIALIZATION PATTERN 
LENGTH field shall be greater than zero and shall not exceed the logical block length. If the INITIALIZATION PATTERN LENGTH field is set to zero 
or is greater than the logical block length, then the device server shall terminate the command with CHECK CONDITION status with the sense 
key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


The INITIALIZATION PATTERN field specifies the data pattern used to write the user data. This data pattern is repeated as necessary to fill each 
logical block. For each logical block, the first byte of the user data shall begin with the first byte of the initialization pattern. Protection informa- 
tion bytes, if any, shall be set to FFFF_FFFF_FFFF_FFFFh. 
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If the INVERT bit is set to one and: 
a) the OVERWRITE COUNT field is an even number, then the pattern used for the first write pass shall consist of: 


A) the user data shall be set to the inversion of the INITIALIZATION PATTERN data; and 
B) protection information bytes, if any, shall be set to 0000_0000_0000_0000h; or 
b) the OVERWRITE COUNT field is an odd number, then the pattern used for the first write pass shall consist of: 
A) the user data is set to the INITIALIZATION PATTERN data; and 
B) protection information bytes, if any, shall be set to FFFF_FFFF_FFFF_FFFFh. 


Following a successful sanitize overwrite service action operation: 
a) the medium shall not be format corrupt; 
b) protection information, if any, set to FFFF_FFFF_FFFF_FFFFh; and 
c) read operations should complete without error. 


3.41.4 SANITIZE command with BLOCK ERASE service action 
The BLOCK ERASE service action (see table 170) performs a sanitize operation using the block erase method (see SBC-4). 
After successful completion of a sanitize block erase, the device server: 
a) may terminate commands that perform read operations to mapped LBAs with: 


A) CHECK CONDITION status with sense key set to MEDIUM ERROR and the appropriate additional sense code for the 
condition; or 


B) if the logical unit is formatted with protection information, CHECK CONDITION status with sense key set to ABORTED 
COMMAND and additional sense code set to one of the protection information check codes shown in Table 98; 


and 


b) should complete read operations to unmapped LBAs without error. (see SBC-4) 


3.41.5 SANITIZE command with CRYPTOGRAPHIC ERASE service action 


The CRYPTOGRAPHIC ERASE service action (see table 170) performs a sanitize operation using the cryptographic erase method 
(see SBC-4. 
After successful completion of the cryptographic erase operation: 


a) if any LBAis mapped and if the logical unit is formatted with protection information, then the device server may terminate read opera- 
tions with CHECK CONDITION status with sense key set to ABORTED COMMAND and additional sense code set to one of the protection 
information check codes shown in Table 98; and 


b) the device server shall process unmapped LBAs as required by logical block provisioning management. 


3.41.6 SANITIZE command with EXIT FAILURE MODE service action 


The EXIT FAILURE MODE service action (see table 98) requests that the device server complete a sanitize operation which 
completed with an error as if the sanitize operation completed without an error (see SBC-4). 


After successful completion of a SANITIZE command with the EXIT FAILURE MODE service action: 


a) if any LBA is mapped (see SBC-4), and the logical unit is formatted with protection information, then the device server may terminate 
commands that perform read operations to mapped LBAs with CHECK CONDITION status with the sense key set to ABORTED COM- 
MAND and the additional sense code set to one of the codes defined in Table 98; and 


b) the device server should complete read operations to unmapped LBAs without error (see SBC-4). 
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3.42 SECURITY PROTOCOL IN command 


3.42.1 


The SECURITY PROTOCOL IN command (see table 173) is used to retrieve security protocol information or the results of one or 
more SECURITY PROTOCOL OUT commands. 


Command description 






























































Table 173 SECURITY PROTOCOL IN command 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (A2h) 
SECURITY PROTOCOL 
2 
2 SECURITY PROTOCOL SPECIFIC 
4 INC_512 Reserved 
5 Reserved 
6 (MSB) 
ALLOCATION LENGTH 
9 (LSB) 
10 Reserved 
11 CONTROL 














SECURITY PROTOCOL field 
The SECURITY PROTOCOL field (see table 174) specifies which security protocol is being used. 















































Table 174 SECURITY PROTOCOL field in SECURITY PROTOCOL IN command 
Code Description Reference 
00h Security protocol information 3.42.2 
01h - 06h Defined by the TCG https://www.trustedcomputinggroup.org 
07h Cbcs SPC-5 
08h - 1Fh Reserved 
20h Tape Data Encryption SSC-3 
21h Data Encryption Configuration ADC-3 
22h - 3Fh Reserved 
40h SA Creation Capabilities SPC-5 
41h IKEv2-SCSI SPC-5 
42h to EBh | Reserved 
ECh JEDEC Universal Flash Storage UFS 
EDh SDcard TrustedFlash Security Systems Specification 1.1.3 http://www.sdcard.org/ 
EEh Authentication in Host Attachments of Transient Storage Deices IEEE 1667 
EFh ATA Device Server Password Security SAT-3 
FOh - FFh Vendor specific 


The contents of the SECURITY PROTOCOL SPECIFIC field depend on the protocol specified by the SECURITY PROTOCOL field (see table 174). 
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INC_512 (512 Increment) 
0 OAn INC_512 bit set to zero specifies that the ALLOCATION LENGTH field (see 2.2.6) expresses the number of bytes to be transferred. 


1 1A 512 increment (INC_512) bit set to one specifies that the ALLOCATION LENGTH field (see 2.2.6) expresses the maximum number of 
bytes available to receive data in increments of 512 bytes (e.g., a value of one means 512 bytes, two means 1,024 bytes, etc.). Pad bytes 
may or may not be appended to meet this length. Pad bytes shall have a value of 00h. 


Indications of data overrun or underrun and the mechanism, if any, for processing retries depend on the protocol specified by 
the SECURITY PROTOCOL field (see table 174). 


Any association between a previous SECURITY PROTOCOL OUT command and the data transferred by a SECURITY PROTOCOL IN 
command depends on the protocol specified by the SECURITY PROTOCOL field (see table 175). If the device server has no data to 
transfer (e.g., the results for any previous SECURITY PROTOCOL OUT commands are not yet available), the device server may 
transfer data indicating it has no other data to transfer. 


The format of the data transferred depends on the protocol specified by the SECURITY PROTOCOL field (see table 174). 
The device server shall retain data resulting from a SECURITY PROTOCOL OUT command, if any, until one of the following events 
is processed: 
a) Transfer of the data via a SECURITY PROTOCOL IN command from the same |_T_L nexus as defined by the protocol specified by the 
SECURITY PROTOCOL field; 
b) Logical unit reset (See SAM-5); or 
c) I|_Tnexus loss (See SAM-5) associated with the I_T nexus that sent the SECURITY PROTOCOL OUT command. 


If the data is lost due to one of these events the application client may send a new SECURITY PROTOCOL OUT command to retry 
the operation. 


SCSI Commands Reference Manual, Rev. J 205 


www.seagate.com Direct Access Block commands (SPC-5 and SBC-4) 


3.42.2 Security protocol information description 


3.42.2.1 Overview 


The purpose of security protocol information security protocol (i.e., the SECURITY PROTOCOL field set to 00h in a SECURITY 
PROTOCOL IN command) is to transfer security protocol related information from the logical unit. A SECURITY PROTOCOL IN 
command in which the SECURITY PROTOCOL field is set to 00h is not associated with a previous SECURITY PROTOCOL OUT 
command and shall be processed without regard for whether a SECURITY PROTOCOL OUT command has been processed. 


If the SECURITY PROTOCOL IN command is supported, the SECURITY PROTOCOL value of 00h shall be supported as defined in 
this standard. 
3.42.2.2. SECURITY PROTOCOL SPECIFIC field 


When the SECURITY PROTOCOL field is set to 00h in a SECURITY PROTOCOL IN command, the SECURITY PROTOCOL SPECIFIC 
field contains a single numeric value as defined in 175. 


Table 175 SECURITY PROTOCOL SPECIFIC field for SECURITY PROTOCOL IN protocol 00h 














Code Description Support Reference 
0000h Supported security protocol list Mandatory 3.42.2.3 
0001h Certificate data Mandatory 3.42.2.4 
0002h Security compliance information Optional 3.42.2.4.1 

0003h - FFFFh Reserved 














All other CDB fields for SECURITY PROTOCOL IN command shall meet the requirements stated in 3.42.1. 


Each time a SECURITY PROTOCOL IN command with the SECURITY PROTOCOL field set to 00h is received, the device server shall 
transfer the data defined in 3.42.2 starting with byte 0. 
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3.42.2.3. Supported security protocols list description 


If the SECURITY PROTOCOL field is set to 00h and the SECURITY PROTOCOL SPECIFIC field is set to 0000h in a SECURITY 
PROTOCOL IN command, the parameter data shall have the format shown in table 176. 


Table 176 Supported security protocols SECURITY PROTOCOL IN parameter data 





Bit 7 6 5 4 3 2 1 0 
Byte 


























0 





Reserved 








6 (MSB) 





SUPPORTED SECURITY PROTOCOL LIST LENGTH (m - 7) ————— 
7 (LSB) 











8 SUPPORTED SECURITY PROTOCOL (first) (00h) 








m SUPPORTED SECURITY PROTOCOL (last) 








Pad bytes (optional) 

















SUPPORTED SECURITY PROTOCOL LIST LENGTH field 
The SUPPORTED SECURITY PROTOCOL LIST LENGTH field indicates the total length, in bytes, of the supported security protocol list that follows. 


SUPPORTED SECURITY PROTOCOL field 


Each SUPPORTED SECURITY PROTOCOL field in the supported security protocols list shall contain one of the security protocol values supported 
by the logical unit. The values shall be listed in ascending order starting with 00h. 
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3.42.2.4 Certificate data description 


3.42.2.4.1 Certificate overview 


A certificate is either an X.509 Public Key Certificate or an X.509 Attribute Certificate depending on the capabilities of the logical 
unit. 


If the SECURITY PROTOCOL field is set to 00h and the SECURITY PROTOCOL SPECIFIC field is set to 0001h in a SECURITY 
PROTOCOL IN command, the parameter data shall have the format shown in table 177. 


Table 177 Certificate data SECURITY PROTOCOL IN parameter data 
























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 

Reserved 
1 
2 (MSB) 
CERTIFICATE LENGTH (m - 3) S| 
3 (LSB) 
4 
CERTIFICATE 

m 

m+1 
Pad bytes (optional) 
n 














CERTIFICATE LENGTH field 

The CERTIFICATE LENGTH field indicates the total length, in bytes, of the certificate or certificates that follow. The length may include more 
than one certificates. If the device server doesn’t have a certificate to transfer, the CERTIFICATE LENGTH field shall be set to 0000h. 
CERTIFICATE field 

The contents of the CERTIFICATE field are defined in 3.42.2.4.2 and 3.42.2.4.3. 


3.42.2.4.2 Public Key certificate description 


RFC 3280 defines the certificate syntax for certificates consistent with X.509v3 Public Key Certificate Specification. Any further 
restrictions beyond the requirements of RFC 3280 are yet to be defined by T10. 


3.42.2.4.3 Attribute certificate description 


FRC 3281 defines the certificate syntax for certificates consistent with X.509v2 Attribute certificate Specification. Any further 
restrictions beyond the requirements of RFC 3281 are yet to be defined by T10. 
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3.42.2.5 Security compliance information description 


3.42.2.5.1 Security compliance information overview 


The security compliance information parameter data contains information about security standards that apply to this SCSI target 
device. 


If the SECURITY PROTOCOL field is set to OOh and the SECURITY PROTOCOL SPECIFIC field is set to 0002h in a SECURITY 
PROTOCOL IN command, then the parameter data shall have the format shown in 


Table 178 Certificate data SECURITY PROTOCOL IN parameter data 





























Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 





SECURITY COMPLIANCE INFORMATION LENGTH (m-3) 
3 (LSB) 











Compliance descriptor [first] 














Compliance descriptor [last] 








m+1 





Pad bytes (optional) 

















SECURITY COMPLIANCE INFORMATION LENGTH field 
The SECURITY COMPLIANCE INFORMATION LENGTH field indicates the total length, in bytes, of the compliance descriptors that follow. 


Each compliance descriptor (see 3.42.2.5.2) contains information about a security standard that applies to this SCSI target device. Compliance 
descriptors may be returned in any order. 


The total data length shall conform to the ALLOCATION LENGTH field requirements (see 2.2.6). Pad bytes may be appended to meet this length. 
Pad bytes shall have a value of 00h. 
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3.42.2.5.2 Compliance descriptor overview 


The format of a compliance descriptor in the security compliance information SECURITY PROTOCOL IN parameter data is shown 
in table 177. 


Table 179 Compliance descriptor format 





Bit 7 6 5 4 3 2 1 0 
Byte 


0 (MSB) 





























Compliance Descriptor Type 
p p yp (LSB) 





N 


Reserved 





w 





> 


(MSB) 





COMPLIANCE DESCRIPTOR LENGTH (n-3) 





N 


(LSB) 








Descriptor specific information 














COMPLIANCE DESCRIPTOR TYPE field 


The COMPLIANCE DESCRIPTOR TYPE field (see table 180) indicates the format of the descriptor specific information. The security compliance 
information SECURITY PROTOCOL IN parameter data may contain more than one compliance descriptor with the same value in the COMPLI- 
ANCE DESCRIPTOR TYPE field. 


Table 180 INFORMATION TYPE 











Code Description Content Reference 
F oe eer : FIPS 140-2 

0001h Peripheral device identifying information FIPS 140-3 3.42.2.5.3 

All other Reserved. 
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3.42.2.5.3. FIPS 140 compliance descriptor 


The FIPS 140 compliance descriptor (see table 181) contains information that may be used to locate information about a FIPS 140 certificate 
associated with the SCSI target device. The SCSI target device may or may not be operating in the mode specified by that certificate. 


Table 181 FIPS 140 Compliance descriptor 













































































Bit 7 6 5 4 3 2 1 0 
Byte 
e ee) Compliance Descriptor Type (0001h) 
1 (LSB) 
2 
5 Reserved 
4 (MSB) 
COMPLIANCE DESCRIPTOR LENGTH (0000 0208h) 
7 (LSB) 
8 REVISION 
9 OVERALL SECURITY LEVEL 
10 
Reserved 
15 
16 (MSB) 
wats Hardware Version 
143 (LSB) | 
144 (MSB) 
ace Version 
271 (LSB) 
272 (MSB) 
ea Module Name 
527 (LSB) 














COMPLIANCE DESCRIPTOR TYPE and COMPLIANCE DESCRIPTOR LENGTH fields 


The COMPLIANCE DESCRIPTOR TYPE field and COMPLIANCE DESCRIPTOR LENGTH field are defined in 3.42.2.5.2 and shall be set as shown in 
table 181 for the FIPS 140 compliance descriptor. 
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REVISION field 
The REVISION field (see table 182) is an ASCII data field (see SPC-5) that indicates the FIPS 140 revision that applies to the SCSI target device. 


Table 182 REVISION field 














Code Related standard 
32h FIPS 140-2 

33h FIPS 140-3 

all others 








OVERALL SECURITY LEVEL field 
The OVERALL SECURITY LEVEL field is an ASCII data field (see SPC-5) that indicates the FIPS 140 overall security level that is reported by NIST. 


HARDWARE VERSION field 


The HARDWARE VERSION field is null terminated, null padded data (see SPC-5) that indicates the version number of the hardware in the mod- 
ule, as reported by NIST. 


VERSION field 


The VERSION field is null terminated, null padded data (see SPC-5) that indicates the version number of the firmware or software in the module, 
as reported by NIST. The value in the VERSION field is not related to the PRODUCT REVISION LEVEL field of standard INQUIRY data (see 3.6.2). 


MODULE NAME field 


The MODULE NAME field is null terminated, null padded data (see SPC-5) that indicates the name or identifier of the cryptographic module, as 
reported by NIST. 
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SECURITY PROTOCOL OUT command 


The SECURITY PROTOCOL OUT command (see table 183) is used to send data to the logical unit. The data sent specifies one or 
more operations to be performed by the logical unit. The format and function of the operations depends on the contents of the 
SECURITY PROTOCOL field (see table 184). Depending on the protocol specified by the SECURITY PROTOCOL field, the 
application client may use the SECURITY PROTOCOL IN command (see 3.42) to retrieve data derived from these operations. 
























































Table 183 SECURITY PROTOCOL OUT command 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (B5h) 
1 SECURITY PROTOCOL 
2 
3 SECURITY PROTOCOL SPECIFIC 
4 INC_512 Reserved 
5 Reserved 
6 (MSB) 
TRANSFER LENGTH 
9 (LSB) 
10 Reserved 
11 CONTROL 














SECURITY PROTOCOL field 
The SECURITY PROTOCOL field (see table 184) specifies which security protocol is being used. 
























































Table 184 SECURITY PROTOCOL field in SECURITY PROTOCOL OUT command 
Code Description Reference 
00h Reserved 
01h - 06h Defined by the TCG https://www.trustedcomputinggroup.org 
07h CbCS SPC-5 
08h - 1Fh Reserved 
20h Tape Data Encryption SSC-3 
21h Data Encryption Configuration ADC-3 
22h - 40h Reserved 
4th IKEv2-SCSI SPC-5 
42h-EBh Reserved 
ECh JEDEC Universal Flash Storage UFS 
EDh SDcard TrustedFlash Security Systems Specification http://www.sdcard.org/ 
EEh Authentication in Host Attachments of Transient Storage Devices IEEE 1667 
EFh ATA Device Server Password Security SAT-3 
FOh - FFh Vendor specific 





SECURITY PROTOCOL SPECIFIC field 
The contents of the SECURITY PROTOCOL SPECIFIC field depend on the protocol specified by the SECURITY PROTOCOL field (see table 184). 
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INC_512 (512 Increment) 
0 AINC_512 bit set to zero specifies that the TRANSFER LENGTH field indicates the number of bytes to be transferred. 


1 INC_512 bit set to one specifies that the TRANSFER LENGTH field (see 2.2.4) expresses the number of bytes to be transferred in incre- 


ments of 512 bytes (e.g., a value of one means 512 bytes, two means 1,024 bytes, etc.). Pad bytes shall be appended as needed to meet 
this requirement. Pad bytes shall have a value of 00h. 


Any association between a SECURITY PROTOCOL OUT command and a subsequent SECURITY PROTOCOL IN command depends 
on the protocol specified by the SECURITY PROTOCOL field (see table 184). Each protocol shall define whether: 


a) The device server shall complete the command with GOOD status as soon as it determines the data has been correctly received. An indi- 


cation that the dat has been processed is obtained by sending a SECURITY PROTOCOL IN command and receiving the results in the 
associated data transfer; or 


b) The device server shall complete the command with GOOD status only after the data has been successfully processed and an associated 
SECURITY PROTOCOL IN command is not required. 


The format of the data transferred depends on the protocol specified by the SECURITY PROTOCOL field (see table 184). 
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This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 












































Table 185 SEEK command (0Bh) 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (OBh) 
1 LUN MSB 
2 
LOGICAL BLOCK ADDRESS 
3 LSB 
4 Reserved 
5 CONTROL 














The Seek command (see table 185) requests that the disk drive seek to the specified logical block address. 


For systems which support disconnection, the disk drive disconnects when a valid Seek command is received. The use of this 
command is infrequent since all commands involving data transfer to/from the disk drive media contain implied seek addresses. 


LUN (Logical Unit Number) field 


Seagate drives only support Logical Unit Number 0. 


LOGICAL BLOCK ADDRESS field 


The maximum Logical Block Address that may be specified for a Seek command is defined in Read Capacity Data (see 3.22.1 and 
3.23.1). See 2.2.3 for the definition of the LOGICAL BLOCK ADDRESS field. 


CONTROL byte 
The CONTROL byte is described in clause 2.2.7. 
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3.45 SEEK EXTENDED command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


Table 186 SEEK command (2Bh) 



































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (2Bh) 

1 LUN Reserved 

2 





LOGICAL BLOCK ADDRESS (MSB) 








LOGICAL BLOCK ADDRESS (LSB) 





Reserved 





Reserved 





Reserved 





wo] orn] aA] u 


CONTROL 














The Seek Extended command (see table 186) requests that the disk drive seek to the specified logical block address. 
This command is implemented with the disk drive specific parameters listed in Table 186. 

LUN (Logical Unit Number) field 

Seagate drives only support Logical Unit Number 0. 

LOGICAL BLOCK ADDRESS field 


Four byte Logical Address may be specified. The drive will seek to this address when the command is received. The maximum 
Logical Block Address that may be specified for a Seek command is defined in Read Capacity Data (see 3.22.1 and 3.23.1). See 
2.2.3 for the definition of the LOGICAL BLOCK ADDRESS field. 


CONTROL byte 
The CONTROL field is described in clause 2.2.7. 
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3.46 SEND DIAGNOSTIC command 


The SEND DIAGNOSTIC command (see table 187) requests the device server to perform diagnostic operations on the SCSI target 
device, on the logical unit, or on both. Logical units that support this command shall implement, at a minimum, the default 
self-test feature (i.e., the SELFTEST bit equal to one and a parameter list length of zero). 



















































































Table 187 SEND DIAGNOSTIC command 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (1Dh) 
1 SELF-TEST CODE PF Reserved SELFTEST DEVOFFL UNITOFFL 
2 Reserved 
3 (MSB) 
PARAMETER LIST LENGTH 
4 (LSB) 
5 CONTROL 
SELFTEST bit 
1 If the SELFTEST bit is set to one, the SELF-TEST CODE field shall contain 000b. 
0 If the SELFTEST bit is set to zero, the contents of SELF-TEST CODE field are specified in table 188. 
SELF-TEST CODE field 
Table 188 SELF-TEST CODE field 
Code Name Description 
This value shall be used when the SELFTEST bit is set to one, or when the SELFTEST bit is set to zero and the 
000b PF bit is set to one. 
If the PF bit, SELFTEST bit, and PARAMETER LIST LENGTH are all zero then no testing is performed and the 
command completes without error. 
001b Background The device server shall start its short self-test (see SPC-5) in the background mode (see SPC-5). 
short self-test The PARAMETER LIST LENGTH field shall contain zero. 
010b Background The device server shall start its extended self-test (see SPC-5) in the background mode (see SPC-5). 
extended self-test The PARAMETER LIST LENGTH field shall contain zero. 
011b | Reserved 
Abort background The device server shall abort the current self-test running in background mode. The PARAMETER LIST 
self-test LENGTH field shall contain zero. This value is only valid if a previous SEND DIAGNOSTIC 
100b command specified a background self-test function and that self-test has not completed. If either of these 
conditions is not met, the command shall be terminated with CHECK CONDITION status, with the sense key 
set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 
101b Foreground The device server shall start its short self-test (see SPC-5) in the foreground mode (see SPC-5). 
short self-test The PARAMETER LIST LENGTH field shall contain zero. 
110b Foreground The device server shall start its extended self-test (see SPC-5) in the foreground mode (see SPC-5). 
extended self-test The PARAMETER LIST LENGTH field shall contain zero. 
111b | Reserved 
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PF (page format) bit 


1 


A page format (PF) bit set to one specifies that the SEND DIAGNOSTIC parameters and any parameters returned by a following RECEIVE 
DIAGNOSTIC RESULTS command with the PCV bit set to zero shall contain a single diagnostic page as defined in 5.1.1. 


0 = APFbit set to zero specifies that all SEND DIAGNOSTIC parameters are vendor specific. If the PARAMETER LIST LENGTH field is set to zero 
and the SEND DIAGNOSTIC command is not going to be followed by a corresponding RECEIVE DIAGNOSTIC RESULTS command with the 
PCV bit set to zero, then the application client shall set the PF bit to zero. The implementation of the PF bit is optional. 

SELFTEST (Self-test) bit 

1 A self-test (SELFTEST) bit set to one specifies that the device server shall perform the logical unit default self-test. If the self-test success- 
fully passes, the command shall be terminated with GOOD status. If the self-test fails, the command shall be terminated with CHECK 
CONDITION status, with the sense key set to HARDWARE ERROR. 

0 ASELFTEST bit set to zero specifies that the device server shall perform the diagnostic operation specified by the SELF-TEST CODE field 


or in the parameter list. The diagnostic operation may require the device server to return parameter data that contains diagnostic 
results. If the return of parameter data is not required, the return of GOOD status indicates successful completion of the diagnostic oper- 
ation. If the return of parameter data is required, the device server shall either: 


a) Perform the requested diagnostic operation, prepare the parameter data to be returned and indicate completion by returning GOOD 
status. The application client issues a RECEIVE DIAGNOSTIC RESULTS command to recover the parameter data; or 


b) Accept the parameter list, and if no errors are detected in the parameter list, return GOOD status. The requested diagnostic operation 
and the preparation of the parameter data to be returned are performed upon receipt of a RECEIVE DIAGNOSTIC RESULTS command. 


UNITOFFL (unit offline) bit 


1 


A unit offline (UNITOFFL) bit set to one specifies that the device server may perform diagnostic operations that may affect the user 
accessible medium on the logical unit (e.g., write operations to the user accessible medium, or repositioning of the medium on sequen- 
tial access devices). The device server may ignore the UNITOFFL bit. 


A UNITOFFL bit set to zero specifies that, after the device server has completed any diagnostic operations specified by the SEND DIAG- 
NOSTIC command, the user accessible medium shall exhibit no effects resulting from the device server's processing the SEND DIAGNOS- 
TIC command that are detectable by any application client. When the SELFTEST bit is set to zero, the UNITOFFL bit shall be ignored. 


DEVOFFEL (SCSI target device offline) bit 


1 


A SCSI target device offline (DEVOFFL) bit set to one grants permission to the device server to perform diagnostic operations that may 
affect all the logical units in the SCSI target device (e.g., alteration of reservations, log parameters, or sense data). The device server may 
ignore the DEVOFFL bit. 


A DEVOFFL bit set to zero specifies that, after the device server has completed any diagnostic operations specified by the SEND DIAG- 
NOSTIC command, no logical unit shall exhibit any effects resulting from the device server's processing the SEND DIAGNOSTIC com- 
mand that are detectable by any application client. If the SELFTEST bit is set to zero, the DEVOFFL bit shall be ignored. 


PARAMETER LIST LENGTH field 


The PARAMETER LIST LENGTH field specifies the length in bytes of the parameter list that shall be transferred from the application client 
Data-Out Buffer to the device server. A parameter list length of zero specifies that no data shall be transferred. This condition shall not be con- 
sidered an error. If PF bit is set to one and the specified parameter list length results in the truncation of the diagnostic page (e.g., the parame- 
ter list length does not match the page length specified in the diagnostic page), then the command shall be terminated with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


To ensure that the diagnostic command information is not destroyed by a command sent from another |_T nexus, the logical 
unit should be reserved. 
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3.47 SET IDENTIFYING INFORMATION command 


The SET IDENTIFYING INFORMATION command (see table 189) requests that the device server set identifying information in the 
logical unit to the value received in the SET IDENTIFYING INFORMATION parameter list. The SET IDENTIFYING INFORMATION 
command is an extension to the SET PERIPHERAL DEVICE/COMPONENT DEVICE IDENTIFIER service action of the MAINTENANCE 
OUT command defined in SCC-2. 


On successful completion of a SET IDENTIFYING INFORMATION command that changes identifying information saved by the 
logical unit, the device server shall establish a unit attention condition (see SAM-5) for the initiator port associated with every |_T 
nexus except the I_T nexus on which the SET IDENTIFIER command was received, with the additional sense code set to DEVICE 
IDENTIFIER CHANGED. 


Table 189 SET IDENTIFYING INFORMATION command 






























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (A4h) 
1 Reserved SERVICE ACTION (06h) 
2 

Reserved 
3 
4 
z RESTRICTED (see SSC-2) 
6 (MSB) 

PARAMETER LIST LENGTH 

9 (LSB) 
10 INFORMATION TYPE Reserved 
11 CONTROL 








PARAMETER LIST LENGTH field 


The PARAMETER LIST LENGTH field specifies the length in bytes of the identifying information that shall be transferred from the 
application client to the device server. A parameter list length of zero specifies that no data shall be transferred, and that 
subsequent REPORT IDENTIFYING INFORMATION commands shall return the INFORMATION LENGTH field set to zero for the 
specified information type. 
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INFORMATION TYPE field 
The INFORMATION TYPE specifies the identifying information type to be set. 


Table 190 INFORMATION TYPE code list 





Code Description 





0000000b Peripheral device identifying information. 


If the PARAMETER LIST LENGTH field is set to greater than the maximum length of the peripheral device 
identifying information, the device server shall terminate the command with CHECK CONDITION status 
with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 





0000010b Peripheral device text identifying information (see 3.32). 


If the PARAMETER LIST LENGTH field is set to a value greater than the maximum length of the peripheral 
device text identifying information (see 3.32), the device server shall terminate the command with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
INVALID FIELD IN CDB. 


If the format of the INFORMATION field is incorrect, the device server shall terminate the command with 
CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
INVALID FIELD IN PARAMETER LIST. 





XXXXXX 1b Restricted (see SCC-2) 














All other Reserved. 





The SET IDENTIFYING INFORMATION parameter list (see table 191) contains the identifying information to be set by the device 
server. 


Table 191 SET IDENTIFYING INFORMATION parameter list 




















Bit 7 6 5 4 3 2 1 0 
Byte 
0 
INFORMATION 
n 
INFORMATION 


The INFORMATION field specifies the identifying information to be set for the specified information type (see 3.32). 


Upon successful completion of a SET IDENTIFYING INFORMATION command, the identifying information that is saved by the 
logical unit shall persist through logical unit resets, hard resets, power loss, |_T nexus losses, media format operations, and media 
replacement. 
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3.48 SET TIMESTAMP command 


The SET TIMESTAMP command (see table 192) requests the device server to initialize a device clock (see SPC-5) if the SCSIP bit is 
set to one in the Control Extension mode page (see 5.3.13). If the SCSIP bit is set to zero, the device server shall terminate the SET 
TIMESTAMP command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense 
code set to INVALID FIELD IN CDB. This command uses the MAINTENANCE OUT CDB format (see SPC-5). 


Table 192 SET TIMESTAMP command 






























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (A4h) 
1 Reserved SERVICE ACTION (OFh) 
2 
Reserved 

5 
6 (MSB) 

PARAMETER LIST LENGTH 
9 (LSB) 
10 Reserved 
11 CONTROL 








OPERATION CODE field 


The OPERATION CODE field is defined in SPC-5 and shall be set as shown in table 276 for the SET TIMESTAMP command. 


SERVICE ACTION field 


The SERVICE ACTION field is defined in 2.2.2 and shall be set as shown in table 276 for the SET TIMESTAMP command. 


PARAMETER LIST LENGTH field 


The PARAMETER LIST LENGTH field specifies the length in bytes of the SET TIMESTAMP parameters that shall be transferred from the applica- 
tion client to the device server. A parameter list length of zero indicates that no data shall be transferred, and that no change shall be made to 


the timestamp. 


CONTROL byte 


The CONTROL byte is defined in Clause 2.2.7. 
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The format for the parameter data returned by the SET TIMESTAMP command is shown in table 193. 


























Table 193 SET TIMESTAMP parameter data format 
Bit 7 6 5 2 1 0 
Byte 

0 

Reserved 
3 
4 

TIMESTAMP 

9 
10 Reserved 
11 Reserved 








TIMESTAMP field 





The TIMESTAMP field specifies the value to which a device clock shall be initialized (see SPC-5). The timestamp should be the number of milli- 
seconds that have elapsed since midnight, 1 January 1970 UT. If the most significant byte in the TIMESTAMP field is greater than FOh, the device 
server shall terminate the command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 


set to INVALID FIELD IN PARAMETER LIST. 


On successful completion of a SET TIMESTAMP command the device server shall establish a unit attention condition for the initiator port asso- 
ciated with every |_T nexus except the I_T nexus on which the SETTIMESTAMP command was received (see SAM-5), with the additional sense 
code set to TIMESTAMP CHANGED. 
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3.49 START STOP UNIT command 


The START STOP UNIT command (see table 194) requests that the device server change the power condition of the logical unit 
(see SBC-4) or load or eject the medium. This includes specifying that the device server enable or disable the direct-access block 
device for medium access operations by controlling power conditions and timers. 


If a START STOP UNIT command is being processed by the device server, and a subsequent START STOP UNIT command for which 
the CDB is validated requests that the logical unit change to a different power condition than was specified by the START STOP 
UNIT command being processed, then the device server shall terminate the subsequent START STOP UNIT command with 
CHECK CONDITION status with the sense key set to NOT READY and the additional sense code set to LOGICAL UNIT NOT READY, 
START STOP UNIT COMMAND IN PROGRESS. 


Table 194 START STOP UNIT command 









































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (1Bh) 

1 Reserved IMMED 

2 Reserved 

3 Reserved POWER CONDITION MODIFER 

4 POWER CONDITION Reserved NO_ FLUSH LOEJ START 

5 CONTROL 














IMMED (Immediate) bit 
0 If the immediate (IMMED) bit is set to zero, then the device server shall return status after the operation is completed. 


1 If the IMMED bit set to one, then the device server shall return status as soon as the CDB has been validated. 


POWER CONDITION field and POWER CONDITION MODIFIER field 


The combinations of values in the POWER CONDITION field and POWER CONDITION MODIFIER field are defined in table 195. If the POWER 
CONDITION field is supported and is set to a value other than Oh, then the START and LOEJ bits shall be ignored. 


Table 195 POWER CONDITION field and POWER CONDITION MODIFIER field 






































POWER | POWER CONDITION | POWER CONDITION Deserpden 
CONDITION Name MODIFIER value 
Oh START_VALID Oh Process the START and LOE) bits. 
th ACTIVE Oh Cause the logical unit to transition to the active power condition (see SPC-5). 
2h IDLE Oh Cause the logical unit to transition to the idle_a power condition (see SPC-5). 
th Cause the logical unit to transition to the idle_b power condition (see SPC-5). 
Cause the logical unit to transition to the idle_c power condition (see SPC-5). 
3h STANDBY Oh Cause the logical unit to transition to the standby_z power condition (see SPC-5). 
th Cause the logical unit to transition to the standby_y power condition (see SPC-5). 
Sh Obsolete Oh to Fh Obsolete 
7h LU_CONTROL Oh Initialize and start all of the idle condition timers that are enabled (see SPC-5), and 
initialize and start all of the standby condition timers that are enabled (see SPC-5). 
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Table 195 POWER CONDITION field and POWER CONDITION MODIFIER field 
































POWER’ | POWER CONDITION | POWER CONDITION Desepuen 
CONDITION Name MODIFIER value 
FORCE_IDLE_O Oh Force the idle_a condition timer to be set to zero (see SPC-5). 
th Force the idle_b condition timer to be set to zero (see SPC-5). 
2h Force the idle_c condition timer to be set to zero (see SPC-5). 
FORCE_STANDBY_0O Oh Force the standby_z condition timer to be set to zero (see SPC-5). 
th Force the standby_y condition timer to be set to zero (see SPC-5). 
All other combinations Reserved 











If the START STOP UNIT command specifies a power condition that conflicts with an operation in progress (e.g., a background 
self test), then, after the START STOP UNIT command completes with GOOD status, the logical unit may not be in the power 
condition that was requested by the command. 


It is not an error to specify that the logical unit transition to its current power condition. 


NO_FLUSH bit 


0 


If the NO_FLUSH bit is set to zero, then logical units that contain cache shall write all cached logical blocks to the medium (e.g., as they 
would do in response to a SYNCHRONIZE CACHE command (see 3.51 and 3.52) with the SYNC_NV bit set to zero, the LOGICAL BLOCK 
ADDRESS field set to zero, and the NUMBER OF LOGICAL BLOCKS field set to zero) prior to entering into any power condition that pre- 
vents accessing the medium (e.g., before the rotating media spindle motor is stopped during transition to the stopped power condi- 
tion). 

If the NO_FLUSH bit is set to one, then cached logical blocks should not be written to the medium by the logical unit prior to entering 
into any power condition that prevents accessing the medium. 


LOEJ (load eject) bit 


0 If the load eject (LOEJ) bit is set to zero, then the logical unit shall take no action regarding loading or ejecting the medium. 

1 If the LOEJ bit is set to one, then the logical unit shall unload the medium if the START bit is set to zero. If the LOEJ bit is set to one, then 
the logical unit shall load the medium if the START bit is set to one. If the POWER CONDITION field is supported and is set to a value other 
than Oh, then the device server shall ignore the LOEJ bit. 

START bit 

0 If the START bit is set to zero, then the device server shall: 
a) cause the logical unit to transition to the stopped power condition; 
b) stop any idle condition timer that is enabled (see SPC-5); and 
c) stop any standby condition timer that is enabled (see SPC-5). 

1 If the START bit set to one, then the device server shall: 


1. comply with requirements defined in SCSI transport protocol standards (e.g., the NOTIFY (ENABLE SPINUP) requirement (see SAS-4); 
2. cause the logical unit to transition to the active power condition; 

3. initialize and start any idle condition timer that is enabled; and 

4. initialize and start any standby condition timer that is enabled. 


If the POWER CONDITION field is supported and is set to a value other than Oh, then the device server shall ignore the START bit. 
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3.50 STREAM CONTROL command 


3.50.1 STREAM CONTROL command overview 


The STREAM CONTROL command (see table 196) requests the device server to open a stream and return the stream identifier in 
the return parameter data or close the stream specified in the STR_ID field in the CDB. 


This command uses the SERVICE ACTION IN (16) CDB format (see SBC-4 - Annex A.2). 


Table 196 STREAM CONTROL command 



























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (9Eh) 
1 Reserved STR_CLTL SERVICE ACTION (14h) 
2 
Reserved 
3 
4 (MSB) 
STR_ID 
5 (LSB) 
6 
Reserved 
14 
15 CONTROL 











OPERATION CODE field 


The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the value defined in 
Table 196. 


SERVICE ACTION field 
The SERVICE ACTION field is defined in 2.2.2 and shall be set to the value in table 196. 


STR_CTL and STR_ID fields 
The stream control (STR_CTL) field specifies the operation to be performed as described in table 197. 


Table 197 STR_CTL field 











Code Description 
O1b Open a stream and return the stream identifier in the ASSIGNED_STR_ID field in the returned parameter data. 
10b Close the stream associated with the STR_ID field. 





All others Reserved 














If the STR_CTL field is set to 10b, then the stream identifier (STR_ID) field specifies the stream identifier associated with the requested opera- 
tion. If the STR_CTL field is not set to 10b, then the device server shall ignore the STR_ID field. 
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3.50.2 STREAM CONTROL parameter data 
The STREAM CONTROL parameter data is defined in table 198. 


Table 198 STREAM CONTROL parameter data 


















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PARAMETER LENGTH (07h) 
1 
Reserved 
3 
4 
5 ASSIGNED_STR_ID 
6 
Reserved 
7 














PARAMETER LENGTH field 


The PARAMETER LENGTH field indicates the length of the parameter data and shall be set as shown in table104 for the STREAM CONTROL 
parameter data. 


ASSIGNED_STR_ID field 


If the STR_CTL field was set to 01b (i.e., close) in the STREAM CONTROL command, then the device server shall set the ASSIGNED_STR_ID field 
to a value that is not currently assigned to an open stream by the device server and open that stream. If the STR_CTL field was not set to 01b in 
the STREAM CONTROL command, then the ASSIGNED_STR_ID field is reserved. 


SCSI Commands Reference Manual, Rev. J 226 


www.seagate.com 


3.51 


Direct Access Block commands (SPC-5 and SBC-4) 


SYNCHRONIZE CACHE (10) command 


The SYNCHRONIZE CACHE (10) command (see table 199) requests that the device server ensure that the specified logical blocks 
have their most recent data values recorded in non-volatile cache and/or on the medium. Logical blocks include user data and, if 
the medium is formatted with protection information enabled, protection information. Logical blocks may or may not be 
removed from volatile cache and non-volatile cache as a result of the synchronize cache operation. 





















































Table 199 SYNCHRONIZE CACHE (10) command 
Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (35h) 

1 Reserved Obsolete IMMED Obsolete 
2 (MSB) 
bese LOGICAL BLOCK ADDRESS 

5 (LSB) 
6 Reserved GROUP NUMBER 

7 (MSB) 

NUMBER OF BLOCKS 

8 (LSB) 
9 CONTROL 














OPERATION CODE field 


The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the value defined in 
table 199. 


IMMED (Immediate) bit 


0 


An immediate (IMMED) bit set to zero specifies that the device server shall not return status until the synchronize cache operation has 


been completed. 


An IMMED bit set to one specifies that the device server shall return status as soon as the CDB has been validated. If the IMMED bit is set 
to one and the device server does not support the IMMED bit, the device server shall terminate the command with CHECK CONDITION 
status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 
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If the IMMED bit is set to one and the synchronize cache operation has not completed, then the SYNC_PROG field in the Caching mode page 
(see 5.3.9) defines device server behavior (see table 200). 


Table 200 SYNC_PROG field description 





Code Description 





00b_ | The device server shall not terminate commands due to the synchronize cache operation and shall not provide pollable sense data. 





The device server: 

01b a) shall not terminate commands due to the synchronize cache operation; and 

b) shall provide pollable sense data with the sense key set to NO SENSE, the additional sense code set to SYNCHRONIZE CACHE 
OPERATION IN PROGRESS, and the PROGRESS INDICATION field set to indicate the progress of the synchronize cache operation. 
The device server: 


a) shall process INQUIRY commands, REPORT LUNS commands, REPORT TARGET PORT GROUPS commands, and REQUEST SENSE 
commands; 





b) may process commands that do not require resources used for the synchronize cache operation; 


10b |) shall terminate commands that require resources used for the synchronize cache operation with CHECK CONDITION status with 
the sense key set to NOT READY, the additional sense code set to LOGICAL UNIT NOT READY, SYNCHRONIZE CACHE OPERATION IN 
PROGRESS, and the PROGRESS INDICATION field set to indicate the progress of the synchronize cache operation; and 


d) shall provide pollable sense data with the sense key set to NOT READY, the additional sense code set to LOGICAL UNIT NOT 
READY, SYNCHRONIZE CACHE OPERATION IN PROGRESS, and the PROGRESS INDICATION field set to indicate the progress of the 
synchronize cache operation. 





11b | Reserved 














LOGICAL BLOCK ADDRESS field 
See 2.2.3 for the definition of the LOGICAL BLOCK ADDRESS field. 


GROUP NUMBER field 


The GROUP NUMBER field specifies the group into which attributes associated with the command should be collected. AGROUP NUMBER field 
set to zero specifies that any attributes associated with the command shall not be collected into any group. 


NUMBER OF BLOCKS field 


The NUMBER OF BLOCKS field specifies the number of logical blocks that shall be synchronized, starting with the logical block specified by the 
LOGICAL BLOCK ADDRESS field. A NUMBER OF BLOCKS field set to zero specifies that all logical blocks starting with the one specified in the 
LOGICAL BLOCK ADDRESS field to the last logical block on the medium shall be synchronized. If the logical block address plus the number of 
blocks exceeds the capacity of the medium, the device server shall terminate the command with CHECK CONDITION status with the sense key 
set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. 


A logical block within the range that is not in cache is not considered an error. 
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3.52 


SYNCHRONIZE CACHE (16) command 


Direct Access Block commands (SPC-5 and SBC-4) 


The SYNCHRONIZE CACHE (16) command (see table 201) requests that the device server ensure that the specified logical blocks 
have their most recent data values recorded in non-volatile cache and/or on the medium. Logical blocks include user data and, if 
the medium is formatted with protection information enabled, protection information. Logical blocks may or may not be 
removed from volatile cache and non-volatile cache as a result of the synchronize cache operation. 


Table 201 


SYNCHRONIZE CACHE (16) command 





Bit 
Byte 


7 6 5 4 3 2 1 0 

















0 


OPERATION CODE (91h) 





1 


Reserved Obsolete 











IMMED Reserved 





2 


(MSB) 





LOGICAL BLOCK ADDRESS 


(LSB) 





10 


(MSB) 








13 


NUMBER OF BLOCKS 


(LSB) 





14 


Reserved 





GROUP NUMBER 





15 








CONTROL 








See the SYNCHRONIZE CACHE (10) command (see 3.51) for the definitions of the fields in this command. 
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Direct Access Block commands (SPC-5 and SBC-4) 


3.53 TEST UNIT READY command 


The TEST UNIT READY command (see table 202) provides a means to check if the logical unit is ready. This is not a request for a 
self-test. If the logical unit is able to accept an appropriate medium-access command without returning CHECK CONDITION 
status, this command shall return a GOOD status. If the logical unit is unable to become operational or is in a state such that an 
application client action (e.g., START UNIT command) is required to make the logical unit ready, the command shall be 
terminated with CHECK CONDITION status, with the sense key set to NOT READY. 


Table 202 TEST UNIT READY command 












































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (00h) 
1 
Reserved 
4 
ps fo contron sss 








Table 203 defines the suggested GOOD and CHECK CONDITION status responses to the TEST UNIT READY command. Other 


conditions, including deferred errors, may result in other responses (e.g., BUSY or RESERVATION CONFLICT status). 


Table 203 Preferred TEST UNIT READY responses 






































Status Sense Key Additional Sense Code 
GOOD not applicable not applicable 
CHECK CONDITION ILLEGAL REQUEST LOGICAL UNIT NOT SUPPORTED 
CHECK CONDITION NOT READY LOGICAL UNIT DOES NOT RESPOND TO SELECTION 
| CHECKCONDITION. | | NOTREADY | MEDIUMNOTPRESENT =—(sti‘Sé;*”Y 
CHECK CONDITION NOT READY LOGICAL UNIT NOT READY, CAUSE NOT REPORTABLE 
CHECK CONDITION NOT READY LOGICAL UNIT IS IN PROCESS OF BECOMING READY 
CHECK CONDITION NOT READY LOGICAL UNIT NOT READY, INITIALIZING COMMAND REQUIRED 
CHECK CONDITION NOT READY LOGICAL UNIT NOT READY, MANUAL INTERVENTION REQUIRED 
CHECK CONDITION NOT READY LOGICAL UNIT NOT READY, FORMAT IN PROGRESS 
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3.54 UNMAP command 


3.54.1 UNMAP command overview 


The UNMAP command (see table 204) requests that the device server cause one or more LBAs to be unmapped. The UNMAP 
command is one of the possible commands that shall be implemented by device servers supporting thin provisioning (see 
SBC-4). 


Table 204 UNMAP command 






































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (42h) 
1 Reserved ANCHOR 
2 
Reserved 





Reserved GROUP NUMBER 


(MSB) 





PARAMETER LIST LENGTH 
(LSB) 





wl] o;rn 


CONTROL 














OPERATION CODE field 
The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the value defined in 
table 204. 
ANCHOR bit 
For a thin provisioned logical unit (see SBC-4): 

QO  anANCHOR bit set to zero specifies that any LBA on which an unmap operation is performed shall become deallocated. 

1 an ANCHOR bit set to one specifies that any LBA on which an unmap operation is performed shall become anchored. 
For a resource provisioned logical unit (see SBC-4), any LBA on which an unmap operation is performed shall become anchored (i.e., the com- 
mand is processed as if the ANCHOR bit is set to one). If the ANCHOR bit is set to one, and the ANC_SUP bit in the Logical Block Provisioning 
VPD page (see 5.4.13) is set to zero, then the device server shall terminate the command with CHECK CONDITION status with the sense key set 
to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 
GROUP NUMBER field 
The GROUP NUMBER field specifies the group into which attributes associated with the command should be collected. AGROUP NUMBER field 
set to zero specifies that any attributes associated with the command shall not be collected into any group. 
PARAMETER LIST LENGTH field 
The PARAMETER LIST LENGTH field specifies the length in bytes of the UNMAP parameter data that shall be sent from the application client to 
the device server. A PARAMETER LIST LENGTH set to zero specifies that no data shall be sent. 
CONTROL byte 
The CONTROL byte is described in clause 2.2.7. 
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3.54.2 UNMAP parameter list 


The UNMAP parameter list (see table 205) contains the data sent by an application client along with an UNMAP command. 
Included in the data are an UNMAP parameter list header and block descriptors for LBA extents to be processed by the device 
server for the UNMAP command. The LBAs specified in the block descriptors may contain overlapping extents, and may be in 
any order. 


For each specified LBA: 


a) amapped LBA should be unmapped (see SBC-4), or may remain mapped; and 
b) anunmapped LBA shall remain unmapped. 


Table 205 UNMAP parameter list 













































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
UNMAP DATA LENGTH (n-1) pe | 
1 (LSB) 
2 (MSB) 
UNMAP BLOCK DESCRIPTOR DATA LENGTH (n-7) —— 
3 (LSB) 
4 
Reserved 
7 
UNMAP block descriptors 
8 
UNMAP block descriptor [first] (see table 206) 
23 
n-15 
UNMAP block descriptor [last] (see table 206) 
n 
UNMAP DATA LENGTH field 


The UNMAP DATA LENGTH field specifies the length in bytes of the following data that is available to be transferred from the data-out buffer. 
The UNMAP DATA LENGTH does not include the number of bytes in the UNMAP DATA LENGTH field. 


UNMAP BLOCK DESCRIPTOR DATA LENGTH field 


The UNMAP BLOCK DESCRIPTOR DATA LENGTH field specifies the length in bytes of the UNMAP block descriptor data that is available to be 
transferred from the data-out buffer. The UNMAP BLOCK DESCRIPTOR DATA LENGTH should be a multiple of 16. If the UNMAP BLOCK DESCRIP- 
TOR DATA LENGTH is not a multiple of 16, then the last UNMAP block descriptor is incomplete and shall be ignored. If the UNMAP BLOCK 
DESCRIPTOR DATA LENGTH is set to zero, then no UNMAP block descriptors are included in the UNMAP parameter data. This condition shall not 
be considered an error. 


SCSI Commands Reference Manual, Rev. J 232 


www.seagate.com Direct Access Block commands (SPC-5 and SBC-4) 


Table 206 defines an UNMAP block descriptor. 


Table 206 UNMAP block descriptor 





























Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 





saeee UNMAP LOGICAL BLOCK ADDRESS 





7 (LSB) 





8 (MSB) 





NUMBER OF LOGICAL BLOCKS 





11 (LSB) 








wsees Reserved 

















UNMAP LOGICAL BLOCK ADDRESS 
The UNMAP LOGICAL BLOCK ADDRESS field contains the first LBA of the UNMAP block descriptor to be unmapped. 


NUMBER OF LOGICAL BLOCKS field 


The NUMBER OF LOGICAL BLOCKS field contains the number of LBAs to be unmapped beginning with the LBA specified by the UNMAP LOGI- 
CAL BLOCK ADDRESS field. 


If the NUMBER OF LOGICAL BLOCKS is set to zero, then no LBAs shall be unmapped for this UNMAP block descriptor. This condition shall not be 
considered an error. 


If the LBA specified by the UNMAP LOGICAL BLOCK ADDRESS field plus the number of logical blocks exceeds the capacity of the 
medium, then the device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL 
REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. 


If the total number of logical blocks specified in the UNMAP block descriptor data exceeds the value indicated in the MAXIMUM 
UNMAP LBA COUNT field in the Block Limits VPD page (see 5.4.5), or if the number of UNMAP block descriptors exceeds the 
value of the MAXIMUM UNMAP PARAMETER COUNT field in the Block Limits VPD page, then the device server shall terminate the 
command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
INVALID FIELD IN PARAMETER LIST. 
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3.55 VERIFY (10) command 


The VERIFY (10) command (see table 207) requests that the device server verify the specified logical block(s) on the medium. 
Each logical block includes user data and may include protection information, based on the VRPROTECT field and the medium 
format. 


Table 207 VERIFY (10) command 












































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (2Fh) 

1 VRPROTECT DPO Reserved BYTCHK Obsolete 
2 (MSB) 
ar LOGICAL BLOCK ADDRESS 

5 (LSB) 

6 BS ee POR Reserved GROUP NUMBER 

7 (MSB) 

3 VERIFICATION LENGTH ss) 
9 CONTROL 














Logical units that contain cache shall write referenced cached logical blocks to the medium for the logical unit (e.g., as they 
would do in response to a SYNCHRONIZE CACHE command (see 3.51 and 3.52) with the SYNC_NV bit set to zero, the LOGICAL 
BLOCK ADDRESS field set to the value of the VERIFY command's LOGICAL BLOCK ADDRESS field, and the NUMBER OF BLOCKS 
field set to the value of the VERIFY command's VERIFICATION LENGTH field). 


See the READ (10) command (see 3.16) for the definition of the DPO bit. See 2.2.3 for the definition of the LOGICAL BLOCK 
ADDRESS field. 


GROUP NUMBER field 


The GROUP NUMBER field specifies the group into which attributes associated with the command should be collected. A GROUP 
NUMBER field set to zero specifies that any attributes associated with the command shall not be collected into any group 


If the Verify Error Recovery mode page (see 5.3.35) is implemented, then the current settings in that page specify the verification 
criteria. If the Verify Error Recovery mode page is not implemented, then the verification criteria is vendor-specific. 
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BYTCHK field 
If the byte check (BYTCHK) field is set to 0Ob, then: 


a) 
b) 


c) 


no Data-Out Buffer transfer shall occur; 


for any mapped LBA specified by the command, the device server shall check the protection information from the verify 
operation based on the VRPROTECT field as defined in table 208; and 


for any unmapped LBA specified by the command, the verify operation shall complete without error. 


the BYTCHK field is set to 01b or 11b; 
the VBULS bit is set to zero in the Block Device Characteristics VPD page (see 5.4.3); and 
any LBA specified by the command is unmapped (i.e., deallocated or anchored), 


then the device server shall terminate the command with CHECK CONDITION status with the sense key set to MISCOMPARE and 
the additional sense code set to MISCOMPARE VERIFY OF UNMAPPED LBA. 


the BYTCHK field is set to 01b or 11b; and 

either: 

A) the VBULS bit is set to one in the Block Device Characteristics VPD page; or 
B) all LBAs specified by the command are mapped, 


if the BYTCHK field is set to 01b, then the Data-Out Buffer transfer shall include the number of logical blocks specified by 
the VERIFICATION LENGTH field; 


if the BYTCHK field is set to 11b, then: 
A) the Data-Out Buffer transfer shall include one logical block; and 
B) the device server shall: 
1) duplicate the single logical block, as described in the WRITE SAME command (see 3.73), the number of times 
required to satisfy the VERIFICATION LENGTH field; and 
2) place the duplicated data in the Data-Out Buffer; 


the device server shall check the protection information transferred from the Data-Out Buffer based on the VRPROTECT 
field as defined in table 210; 


for any mapped LBA specified by the command, the device server shall perform the verify operation and check the protec- 
tion information from the verify operation based on the VRPROTECT field as defined in table 209; 


the device server shall perform: 

A) acompare operation of: 

user data from the verify operations; and 
user data from the Data-Out Buffer; 


and 


a) 
b) 


B) acompare operation based on the VRPROTECT field as defined in table 211 of: 
protection information from the verify operations; and 
protection information from the Data-Out Buffer. 


The order of the user data and protection information checks and comparisons is vendor-specific. 


If a byte-by-byte comparison is unsuccessful for any reason, the device server shall terminate the command with CHECK 
CONDITION status with the sense key set to MISCOMPARE and the additional sense code set to the appropriate value for the 
condition. 
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VERIFICATION LENGTH field 


The VERIFICATION LENGTH field specifies the number of contiguous logical blocks that shall be verified, starting with the logical block specified 
by the LOGICAL BLOCK ADDRESS field. If the BYTCHK field is set to one, the VERIFICATION LENGTH field also specifies the number of logical blocks 
that the device server shall transfer from the data-out buffer. A VERIFICATION LENGTH field set to zero specifies that no logical blocks shall be veri- 
fied. This condition shall not be considered as an error. Any other value specifies the number of logical blocks that shall be verified. If the logical 
block address plus the verification length exceeds the capacity of the medium, the device server shall terminate the command with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. 
The VERIFICATION LENGTH field is constrained by the MAXIMUM TRANSFER LENGTH field in the Block Limits VPD page. 


If the BYTCHK field is set to 0Ob, then the device server shall check the protection information read from the medium based on 
the VRPROTECT field as described in table 208. 


Table 208 VRPROTECT field with BYTCHK field set to 0Ob - medium (Sheet 1 of 2) 




































































Code pea an Field in protection Bees Bee If check fails [41 le], 
protection information [g] additional sense code 
information Nalue {i 
LOGICAL BLOCK GRD_CHK = 1 LOGICAL BLOCK GUARD CHECK FAILED 
evene GRD_CHK=0 No check performed 
: LOGICAL BLOCK APP_CHK = 1 [c] LOGICAL BLOCK APPLICATION TAG CHECK FAILED 
000b Yes APPRICRTIONTAG | pp CHK SO No check performed 
LOGICAL BLOCK REF_CHK = 1 [h] LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
BEFERENGE ENG REF_CHK=0 No check performed 
No No protection information on the medium to check. Only user data is checked. 
LOGICAL BLOCK GRD_CHK = 1 LOGICAL BLOCK GUARD CHECK FAILED 
Gnane GRD_CHK=0 No check performed 
LOGICAL BLOCK APP_CHK = 1 [c] LOGICAL BLOCK APPLICATION TAG CHECK FAILED 
1 ae Nes BPEREAVONTAS APP_CHK=0 No check performed 
LOGICAL BLOCK REF_CHK = 1 [h] LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
BEFERENEE TAG REF_CHK=0 No check performed 
No Error condition [a] 
ae oe No check performed 
LOGICAL BLOCK APP_CHK = 1 [c] LOGICAL BLOCK APPLICATION TAG CHECK FAILED 
010b [b] Yes perenne APP_CHK =0 No check performed 
LOGICAL BLOCK REF_CHK = 1 [h] LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
REL ERNE IG REF_CHK=0 No check performed 
No Error condition [a] 
Fakes on No check performed 
LOGICAL BLOCK 
011b [b] Yes APPLICATION TAG No check performed 
LOGICAL BLOCK No check performed 
REFERENCE TAG 
No Error condition [a] 
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Table 208 VRPROTECT field with BYTCHK field set to 00b - medium (Sheet 2 of 2) 





























Logical unit 
formatted with [Field in protection | Fxtended INQUIRY If check fails (4121, 
Code A : A Data VPD page bit co 
protection information [g] additional sense code 
: A value [f] 
information 
LOGICAL BLOCK GRD_CHK = 1 LOGICAL BLOCK GUARD CHECK FAILED 
fs GRD_CHK=0 No check performed 
LOGICAL BLOCK 
100b [b] ve APPLICATION TAG No check performed 
LOGICAL BLOCK 
REFERENCE TAG No check performed 
No Error condition [a] 
101b- | Reserved 
111b 








[a] A verify operation to a logical unit that supports protection information and has not been formatted with protection informa- 

tion shall be terminated with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense 

code set to INVALID FIELD IN CDB. 

If the logical unit does not support protection information the requested command should be terminated with CHECK CONDI- 

TION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 

[c] If the device server has knowledge of the contents of the LOGICAL BLOCK APPLICATION TAG field, then the device server shall 
check each logical block application tag. If the ATO bit in the Control mode page (see 5.3.12) is set to one, then this knowledge 
is acquired from: 


a) the EXPECTED LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in the CDB, if| 
a VERIFY (32) command (see 3.58) is received by the device server; 


[b 


=a 


b) the Application Tag mode page (see 5.3.6), if a command other than VERIFY (32) is received by the device server, and the 
ATMPE bit in the Control mode page (see 5.3.12) is set to one; or 


c) amethod not defined by this standard, if a command other than VERIFY (32) is received by the device server, and the 
ATMPE bit is set to zero. 


If an error is reported, the sense key shall be set to ABORTED COMMAND. 
If multiple errors occur, the selection of which error to report is not defined by this manual. 


[f] See the Extended INQUIRY Data VPD page (see 5.4.9) for the definitions of the GRD_CHK bit, the APP_CHK bit, and the 
REF_CHK bits. 


If the application client or device server detects a: 
a) LOGICAL BLOCK APPLICATION TAG field set to FFFFh and type 1 protection (see SBC-4) or type 2 protection 
(see SBC-4) is enabled; or 


b) LOGICAL BLOCK APPLICATION TAG field set to FFFFh, LOGICAL BLOCK REFERENCE TAG field set to FFFF FFFFh, 
and type 3 protection (see SBC-4) is enabled, 
then the device server shall not check any protection information in the associated logical block. 


[d 


[e 


Se 


=o 


Ig 


[h] If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to the lower 4 bytes 
of the LBA associated with the logical block. If type 2 protection or type 3 protection is enabled, the device server 
checks the logical block reference tag if it has knowledge of the contents of the LOGICAL BLOCK REFERENCE TAG 
field. If type 2 protection is enabled, then this knowledge may be acquired through the EXPECTED INITIAL LOGI- 
CAL BLOCK REFERENCE TAG field in a VERIFY (32) command (see 3.58). If type 3 protection is enabled, then the 
method for acquiring this knowledge is not defined by this manual. 








[i] If the DPICZ bit in the Control mode page (see 5.3.12) is set to one, then protection information shall not be checked. 
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If the BYTCHK field is set to 01b or 11b, then the device server shall check the protection information read from the medium based on the 
VRPROTECT field as described in table 209. 


Table 209 VRPROTECT field with BYTCHK field set to 01b or 11b - medium (Sheet 1 of 2) 





















































Logical unit formatted | _. ,,. ; Extended INQUIRY 
s1< [d] [el 
Code with protection Goomenat ae Data VPD page bit reece d 
information 9 value [f] additional sense code 
Yes lil LOGICAL BLOCK GRD_CHK = 1 LOGICAL BLOCK GUARD CHECK FAILED 
SunRe GRD_CHK=0 No check performed 
LOGICAL BLOCK APP_CHK = 1 Ic] [g] | LOGICAL BLOCK APPLICATION TAG CHECK FAILED 
000b AEE DEATION TRS APP_CHK=0 No check performed 
LOGICAL BLOCK REF_CHK = 1 [h] LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
pErERENCEING REF_CHK=0 No check performed 
No No protection information on the medium available to check 
Yes LOGICAL BLOCK No check performed 
001b GUARD 
010b LOGICAL BLOCK No check performed 
011b APPLICATION TAG 
100b LOGICAL BLOCK No check performed 
101b [b] REFERENCE TAG 
No Error condition [a] 
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Table 209 VRPROTECT field with BYTCHK field set to 01b or 11b - medium (Sheet 2 of 2) 





Logical unit formatted | _. ,,. : Extended INQUIRY «a. [dl fel 
Code with protection a ae ee Data VPD page bit If check ee 
information 9g value [f] additional sense code 














110b- | Reserved 
111b 








[a] A verify operation to a logical unit that supports protection information and has not been formatted with protection information shall be 
terminated with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID 
FIELD IN CDB. 

[b] If the logical unit does not support protection information the requested command should be terminated with CHECK CONDITION status 
with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 

[c] If the device server has knowledge of the contents of the LOGICAL BLOCK APPLICATION TAG field, then the device server shall check each 
logical block application tag. If the ATO bit in the Control mode page (see 5.3.12) is set to one, then this knowledge is acquired from: 

a) the EXPECTED LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in the CDB, if a VERIFY 
(32) command (see 3.58) is received by the device server; 

b) the Application Tag mode page (see 5.3.6) if a command other than VERIFY (32) is received by the device server, and 
the ATMPE bit in the Control mode page (see 5.3.12) is set to one; or 

c) amethod not defined by this standard, if a command other than VERIFY (32) is received by the device server, and the 
ATMPE bit is set to zero. 

[d] If an error is reported, the sense key shall be set to ABORTED COMMAND. 

[e] If multiple errors occur, the selection of which error to report is not defined by this manual. 

[f] See the Extended INQUIRY Data VPD page (see 5.4.9) for the definitions of the GRD_CHK bit, the APP_CHK bit, and the REF_CHK bit. 

[g] If the application client or device server detects a: 

a) logical block application tag field set to FFFFh and type 1 protection or type 2 protection is enabled; or 

b) logical block application tag field set to FFFFh, logical block reference tag field set to FFFF FFFFh, and type 3 protection 
is enabled, 
then the device server shall not check any protection information in the associated logical block. 

[h] If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to the lower 4 bytes of the 
LBA associated with the logical block. If type 2 protection or type 3 protection is enabled, the device server checks the logical 
block reference tag if it has knowledge of the contents of the logical block reference tag field. If type 2 protection is 
enabled, then this knowledge may be acquired through the expected initial logical block reference tag field in a VERIFY (32) 
command (see 3.58). If type 3 protection is enabled, then the method for acquiring this knowledge is not defined by this 
manual. 

[i] If the DPICZ bit in the Control mode page (see 5.3.12) is set to one, then protection information shall not be checked. 
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If the BYTCHK field is set to 01b or 11b, then the device server shall check the protection information transferred from the data-out buffer based 
on the VRPROTECT field as described in table 210. 


Table 210 VRPROTECT field with BYTCHK field set to one 01b or 11b - data-out buffer (Sheet 1 of 2) 

































































Logical unit neat 
formatted with edn Device server 
i +1 [d] [el iti 
Code protection iprotectian check If check fails , additional sense code 
‘ E information 
information 
naam Yes No protection information received from application client to check 
No No protection information received from application client to check 
LOGICAL BLOCK Shall LOGICAL BLOCK GUARD CHECK FAILED 
GUARD 
Yes LOGICAL BLOCK May [c] LOGICAL BLOCK APPLICATION TAG CHECK FAILED 
001b [b] APPLICATION TAG 
LOGICAL BLOCK Shall [f] LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
REFERENCE TAG 
No Error condition [a] 
LOGICAL BLOCK Shall not No check performed 
GUARD 
— LOGICAL BLOCK May [c] LOGICAL BLOCK APPLICATION TAG CHECK FAILED 
010b [b] APPLICATION TAG 
LOGICAL BLOCK May [f] LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
REFERENCE TAG 
No Error condition [a] 
LOGICAL BLOCK Shall not No check performed 
GUARD 
Yes LOGICAL BLOCK Shall not No check performed 
011b [b] APPLICATION TAG 
LOGICAL BLOCK Shall not No check performed 
REFERENCE TAG 
No Error condition [a] 
LOGICAL BLOCK Shall LOGICAL BLOCK GUARD CHECK FAILED 
GUARD 
Yes LOGICAL BLOCK Shall not No check performed 
100b [b] APPLICATION TAG 
LOGICAL BLOCK Shall not No check performed 
REFERENCE TAG 
No Error condition [a] 
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Table 210 VRPROTECT field with BYTCHK field set to one 01b or 11b - data-out buffer (Sheet 2 of 2) 





























Logical unit Field in 
formatted with Device server 
i s1- [d] [el] iti 
Code protection ee check If check fails '"''“!, additional sense code 
information 
LOGIES BLOCK Shall LOGICAL BLOCK GUARD CHECK FAILED 
GUARD 
LOGICAL BLOCK 
Yes APPLICATION May [cl LOGICAL BLOCK pies ae TAG CHECK 
101b [b] TAG 
LOGICAL BLOCK 
REFERENCE TAG May [fl LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
No Error condition [a] 
110b- 
111b Reserved 








[a] A verify operation to a logical unit that supports protection information and has not been formatted with protection 
information shall be terminated with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the addi- 
tional sense code set to INVALID FIELD IN CDB. 

[b] If the logical unit does not support protection information the requested command should be terminated with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 

[c] If the device server has knowledge of the contents of the LOGICAL BLOCK APPLICATION TAG field, then the device server 
shall check each logical block application tag. If the ATO bit in the Control mode page (see 5.3.12) is set to one, then this 
knowledge is acquired from: 
a) the EXPECTED LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in the 

CDB, if a VERIFY (32) command (see 3.58) is received by the device server; 
b) the Application Tag mode page (see 5.3.6), if a command other than VERIFY (32) is received by the device 
server, and the ATMPE bit in the Control mode page (see 5.3.12) is set to one; or 
c) amethod not defined by this standard, if a command other than VERIFY (32) is received by the device 
server, and the ATMPE bit is set to zero. 

[d] If an error is reported, the sense key shall be set to ABORTED COMMAND. 

[e] If multiple errors occur, the selection of which error to report is not defined by this manual. 

[f] If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to 
the lower 4 bytes of the LBA associated with the logical block. If type 2 protection or type 3 protection is 
enabled, the device server checks the logical block reference tag if it has knowledge of the contents of the 
logical block reference tag field. If type 2 protection is enabled, then this knowledge may be acquired 
through the expected initial logical block reference tag field in a VERIFY (32) command (see 3.58). If type 3 

protection is enabled, then the method for acquiring this knowledge is not defined by this manual. 
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If the BYTCHK field is set to 01b or 11b, then the device server shall perform a byte-by-byte comparison of protection information transferred from 
the data-out buffer with protection information read from the medium based on the VRPROTECT field as described in table 211. 


Table 211 VRPROTECT field with BYTCHK field set to 01b or 11b - byte-by-byte comparison requirements (Sheet 1 of 2) 



























































Logical unit 
i -by- ; [d] 
Code | formatted with Field Byte-by-byte If compare fails [c] ", 
protection Comparison additional sense code 
information 
Yes No protection information received from application client to compare. Only user data is compared within 
each logical block. 
000b 
No No protection information or the medium or received from application client to compare. Only user data is 
compared within each logical block. 
LOGICAL BLOCK GUARD Shall LOGICAL BLOCK GUARD CHECK FAILED 
LOGICAL BLOCK APPLICATION TAG Shall LOGICAL BLOCK APPLICATION TAG CHECK 
(ATO = 1) [el FAILED 
LOGICAL BLOCK APPLICATION TAG Shall not No compare performed 
(ATO = 0) [fl 
Yes 
001b [b] LOGICAL BLOCK REFERENCE TAG Shall LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
LOGICAL BLOCK REFERENCE TAG Shall LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
(type 3 and ATO = 0) 
LOGICAL BLOCK REFERENCE TAG Shall not No compare performed 
(type 3 and ATO = 1) 
No Error condition [a] 
LOGICAL BLOCK GUARD Shall not No compare performed 
LOGICAL BLOCK APPLICATION TAG Shall LOGICAL BLOCK APPLICATION TAG CHECK 
(ATO = 1) [e] FAILED 
LOGICAL BLOCK APPLICATION TAG Shall not No compare performed 
(ATO = 0) [fl 
010b [b] me? LOGICAL BLOCK REFERENCE TAG Shall LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
(not type 3) 
LOGICAL BLOCK REFERENCE TAG Shall LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
(type 3 and ATO=0 
LOGICAL BLOCK REFERENCE TAG Shall not No compare performed 
(type 3 and ATO = 1) 
No Error condition [a] 
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Table 211 VRPROTECT field with BYTCHK field set to 01b or 11b - byte-by-byte comparison requirements (Sheet 2 of 2) 
Logical unit 
Code _| formatted with Field Byte-by-byte If compare fails [c] Se 
protection Comparison additional sense code 
information 
LOGICAL BLOCK GUARD Shall LOGICAL BLOCK GUARD CHECK FAILED 
LOGICAL BLOCK APPLICATION TAG Shall LOGICAL BLOCK APPLICATION TAG CHECK 
(ATO = 1) [e] FAILED 
LOGICAL BLOCK APPLICATION TAG Shall not No compare performed 
(ATO = 0) [fl 
010b [b] Yes LOGICAL BLOCK REFERENCE TAG Shall LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
100b (not type 3) 
LOGICAL BLOCK REFERENCE TAG Shall LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
(type 3 and ATO=0 
LOGICAL BLOCK REFERENCE TAG Shall not No compare performed 
(type 3 and ATO = 1) 
No Error condition [a] 
LOGICAL BLOCK GUARD Shall LOGICAL BLOCK GUARD CHECK FAILED 
LOGICAL BLOCK APPLICATION TAG Shall LOGICAL BLOCK APPLICATION TAG CHECK 
(ATO = 1) [e] FAILED 
Yes 
101b [b] LOGICAL BLOCK APPLICATION TAG Shall not No compare performed 
(ATO = 0) [fl 
LOGICAL BLOCK REFERENCE TAG Shall LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
No Error condition [a] 
110b - 
111b Reserved 








[b 


= 


Id 


oS 





[a] A verify operation to a logical unit that supports protection information and has not been formatted with protection information shall be 
terminated with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID 
FIELD IN CDB. 


If the logical unit does not support protection information the requested command should be terminated with CHECK CONDITION status 
with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 


[c] Ifan error is reported, the sense key shall be set to MISCOMPARE. 
If multiple errors occur, the selection of which error to report is not defined by this manual. 


[e] If the ATO bit is set to one in the Control mode page (see 5.3.12), the logical block application tag shall not be 
modified by a device server. 


[f] If the ATO bit is set to zero in the Control mode page (see 5.3.12), the logical block application tag may be modified by a device server. 
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3.56 VERIFY (12) command 


The VERIFY (12) command (see table 212) requests that the device server verify the specified logical block(s) on the medium. 
Each logical block includes user data and may include protection information, based on the VRPROTECT field and the medium 
format. 


Table 212 VERIFY (12) command 

































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (AFh) 
1 VRPROTECT DPO Reserved BYTCHK Obsolete 
2 (MSB) 
LOGICAL BLOCK ADDRESS 

5 (LSB) 
6 (MSB) 

VERIFICATION LENGTH 
9 (LSB) 
10 baal Reserved GROUP NUMBER 
1 CONTROL 











See the VERIFY (10) command (see 3.55) for the definitions of the fields in this command. 
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3.57 VERIFY (16) command 


The VERIFY (16) command (see table 213) requests that the device server verify the specified logical block(s) on the medium. Each 
logical block includes user data and may include protection information, based on the VRPROTECT field and the medium format. 


Table 213 VERIFY (16) command 






























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (8Fh) 

1 VRPROTECT DPO Reserved BYTCHK Reserved 
2 (MSB) 

LOGICAL BLOCK ADDRESS 
9 (LSB) 
10 (MSB) 
VERIFICATION LENGTH 

13 (LSB) 
Le ar israae Reserved GROUP NUMBER 
15 CONTROL 














See the VERIFY (10) command (see 3.55) for the definitions of the fields in this command. 
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3.58 VERIFY (32) command 


The VERIFY (32) command (see table 214) requests that the device server verify the specified logical block(s) on the medium. 
Each logical block includes user data and may include protection information, based on the VRPROTECT field and the medium 
format. 


The VERIFY (32) command shall only be processed if type 2 protection is enabled (see SPC-5). 


Table 214 VERIFY (32) command 































































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (7Fh) 
1 CONTROL 
2 
Reserved 
5 
6 Reserved GROUP NUMBER 
7 ADDITIONAL CDB LENGTH (18h) 
8 (MSB) 
SERVICE ACTION (OO0Ah) ——_ 
9 (LSB) 
10 VRPROTECT DPO Reserved BYTCHK Reserved 
11 Reserved 
12 (MSB) 
ars LOGICAL BLOCK ADDRESS 
19 (LSB) 
20 (MSB) 
awe EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 
23 (LSB) 
24 (MSB) 
35 EXPECTED LOGICAL BLOCK APPLICATION TAG se) 
26 (MSB) 
WW LOGICAL BLOCK APPLICATION TAG MASK —— 
27 (LSB) 
28 (MSB) 





see VERIFICATION LENGTH 
31 (LSB) 
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See the VERIFY (10) command (see 3.55) for the definitions of the GROUP NUMBER field, VRPROTECT field, DPO bit, BYTCHK field, 
LOGICAL BLOCK ADDRESS field, and VERIFICATION LENGTH field. 


When checking of the LOGICAL BLOCK REFERENCE TAG field is enabled (see table 208, table 209, table 210, and table 211 in 
3.55), the EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG field contains the value of the LOGICAL BLOCK REFERENCE TAG 
field expected in the protection information of the first logical block accessed by the command instead of a value based on the 
LBA. 


If the ATO bit is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK APPLICATION TAG field is 
enabled (see table 208, table 209, table 210, and table 211 in 3.55), the LOGICAL BLOCK APPLICATION TAG MASK field contains a 
value that is a bit mask for enabling the checking of the LOGICAL BLOCK APPLICATION TAG field in the protection information for 
each logical block accessed by the command. A LOGICAL BLOCK APPLICATION TAG MASK bit set to one enables the checking of 
the corresponding bit of the EXPECTED LOGICAL BLOCK APPLICATION TAG field with the corresponding bit of the LOGICAL 
BLOCK APPLICATION TAG field in the protection information. 


If the ATO bit is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK APPLICATION TAG field is 
disabled (see table 208, table 209, table 210, and table 211 in 3.55), or if the ATO bit is set to zero, the LOGICAL BLOCK 
APPLICATION TAG MASK field and the EXPECTED LOGICAL BLOCK APPLICATION TAG field shall be ignored. 


The LOGICAL BLOCK APPLICATION TAG MASK field and the EXPECTED LOGICAL BLOCK APPLICATION TAG field shall be ignored if: 


a) the ATO bit is set to zero; or 
b) the ATO bit is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK APPLICATION TAG field 
is disabled (see table 208, table 209, table 210, and table 211 in 3.55). 
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3.59 WRITE (6) command 


This command has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


The WRITE (6) command (see table 215) requests that the device server transfer the specified logical block(s) from the data-out 
buffer and write them. Each logical block transferred includes user data but does not include protection information. Each 
logical block written includes user data and, if the medium is formatted with protection information enabled, protection 
information. 


Table 215 WRITE (6) command 





















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (OAh) 

1 Reserved (MSB) 

2 LOGICAL BLOCK ADDRESS 

3 (LSB) 

4 TRANSFER LENGTH 

5 CONTROL 





The cache control bits are not provided for this command. Direct-access block devices with cache may have values for the cache 
control bits that may affect the WRITE (6) command, however no default value is defined by this manual. If explicit control is 
required, the WRITE (10) command should be used. 


LOGICAL BLOCK ADDRESS field 
See 2.2.3 for the definition of the LOGICAL BLOCK ADDRESS field. 


TRANSFER LENGTH field 


The TRANSFER LENGTH field specifies the number of contiguous logical blocks of data that shall be transferred from the data-out buffer 
and written, starting with the logical block specified by the LOGICAL BLOCK ADDRESS field. A TRANSFER LENGTH field set to zero spec- 
ifies that 256 logical blocks shall be written. Any other value specifies the number of logical blocks that shall be written. If the logical 
block address plus the transfer length exceeds the capacity of the medium, the device server shall terminate the command with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF 
RANGE. The TRANSFER LENGTH field is constrained by the MAXIMUM TRANSFER LENGTH field in the Block Limits VPD page. 


If a WRITE (6) command is received after protection information is enabled the device server shall set the protection information as 
follows as it writes each logical block to the medium: 


a) the LOGICAL BLOCK GUARD field set to a properly generated CRC (see SPC-5); 
b) the LOGICAL BLOCK REFERENCE TAG field set to: 


A) _ the least significant four bytes of the LBA, if type 1 protection (see SPC-5) is enabled; or 
B) FFFFFFFFh, if type 2 protection or type 3 protection is enabled 


and 
a) the LOGICAL BLOCK APPLICATION TAG field set to: 
C) _ FFFFh, if the ATO bit is set to one in the Control mode page (see 5.3.12); or 
D) any value, if the ATO bit is set to zero in the Control mode page (see 5.3.12). 
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3.60 WRITE (10) command 


The WRITE (10) command (see table 216) requests that the device server transfer the specified logical block(s) from the data-out 
buffer and write them. Each logical block transferred includes user data and may include protection information, based on the 
WRPROTECT field and the medium format. Each logical block written includes user data and, if the medium is formatted with 
protection information enabled, protection information. 


Table 216 WRITE(10) command 





















































Bit 7 6 5 4 3 2 1 (0) 
Byte 

0 OPERATION CODE (2Ah) 
1 WRPROTECT DPO FUA Reserved Obsolete Obsolete 
2 (MSB) 

LOGICAL BLOCK ADDRESS 
5 (LSB) 
6 Reserved GROUP NUMBER 
7 (MSB) 

TRANSFER LENGTH 

8 (LSB) 
9 CONTROL 











See the READ (10) command (see 3.16) for the definition of the DPO bit. See 2.2.3 for the definition of the LOGICAL BLOCK 
ADDRESS field. See 2.2.8 and SPC-5 for the definition of the GROUP NUMBER field. 


The device server shall check the protection information transferred from the data-out buffer based on the WRPROTECT field as 
described in table 217. 
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Table 217 WRPROTECT field (Sheet 1 of 2) 
Logical unit 
code | with | ‘Fleldinertecten |” evice server heck ee 
protection 
information 
sees Yes [f] [g] [h] No protection information received from application client to check 
No No protection information received from application client to check 
LOGICAL BLOCK GUARD Shall LOGICAL BLOCK GUARD CHECK FAILED 
001b [b] Yes [e] LOGICAL BLOCK APPLICATION TAG | Dependent on RWWP [c] | LOGICAL BLOCK APPLICATION TAG CHECK FAILED 
LOGICAL BLOCK REFERENCE TAG | Shall (except for type 3)j LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
No [a] No protection information available to check 
LOGICAL BLOCK GUARD Shall not No check performed 
Yes [e] LOGICAL BLOCK APPLICATION TAG | Dependent on RWWP [c] | LOGICAL BLOCK APPLICATION TAG CHECK FAILED 
eis LOGICAL BLOCK REFERENCE TAG May [j] LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
No [a] No protection information available to check 
LOGICAL BLOCK GUARD Shall not No check performed 
sib Yes [e] LOGICAL BLOCK APPLICATION TAG Shall not No check performed 
ye LOGICAL BLOCK REFERENCE TAG Shall not No check performed 
No [a] No protection information available to check 
LOGICAL BLOCK GUARD Shall LOGICAL BLOCK GUARD CHECK FAILED 
1006 16) Yes [e] LOGICAL BLOCK APPLICATION TAG Shall not No check performed 
LOGICAL BLOCK REFERENCE TAG Shall not No check performed 
No [a] No protection information available to check 
LOGICAL BLOCK GUARD Shall LOGICAL BLOCK GUARD CHECK FAILED 
101b [b] Yes [e] LOGICAL BLOCK APPLICATION TAG | Dependent on RWWP [c] | LOGICAL BLOCK APPLICATION TAG CHECK FAILED 
LOGICAL BLOCK REFERENCE TAG May [j] LOGICAL BLOCK REFERENCE TAG CHECK FAILED 
No [a] No protection information available to check 
110b-111b Reserved 
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Table 217. WRPROTECT field (Sheet 2 of 2) 








Logical unit 
eee Field in protection If check fails [d] [i] 
Code with : P A Device server check bas 
‘ information [k] additional sense code 
protection 
information 














[a] A write operation to a logical unit that supports protection information and has not been formatted with protection 
information shall be terminated with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional 
sense code set to INVALID FIELD IN CDB. 


[b] If the logical unit does not support protection information the requested command should be terminated with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 

[c] If the device server has knowledge of the contents of the LOGICAL BLOCK APPLICATION TAG field, and the ATO bit is set to one 
in the Control mode page (see 5.3.12), then the device server: 

a) may check each logical block application tag if the RWWP bit is set to zero in the Control mode page (see 5.3.12); and 
b) shall check each logical block application tag if the RWWP bit is set to one in the Control mode page. 
If the ATO bit in the Control mode page (see 5.3.12) is set to one, then this knowledge is acquired from: 
a) the EXPECTED LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in the CDB, 
if a WRITE (32), WRITE ATOMIC (32), WRITE SAME (32), or a WRITE STREAM (32) command is received by the device server; 
b) the Application Tag mode page (see 5.3.6), if a command other than WRITE (32), WRITE ATOMIC (32), WRITE SAME (32), or 
a WRITE STREAM (32) command is received by the device server and the ATMPE bit in the Control mode page (see 5.3.12) 
is set to one or 
c) amethod not defined by this standard, if a command other than WRITE (32), WRITE ATOMIC (32), WRITE SAME (32), or a 
WRITE STREAM (32) command is received by the device server, and the ATMPE bit is set to zero. 

[d] If an error is reported, the sense key shall be set to ABORTED COMMAND. 

[e] Device server shall preserve the contents of protection information (e.g., write to medium, store in non-volatile memory). 

[f] The device server shall write a properly generated CRC into each LOGICAL BLOCK GUARD field. 

[g] If the RWWP bit in the Control mode page (see 5.3.12) is set to one, then the device server shall terminate the command with 
CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN 
CDB. If the RWWP bit is set to zero, and: 

a) type 1 protection is enabled, then the device server shall write the least significant four bytes of each LBA into the 
LOGICAL BLOCK REFERENCE TAG field of each of the written logical blocks; or 

b) type 2 protection or type 3 protection is enabled, then the device server shall write a value of FFFF_FFFFh into the 
LOGICAL BLOCK REFERENCE TAG field of each of the written logical blocks. 

[h] If the ATO bit is set to one in the Control mode page (see 5.3.12), the device server shall write FFFFh into each LOGICAL BLOCK 
APPLICATION TAG field. If the ATO bit is set to zero, the device server may write any value into each LOGICAL BLOCK 
APPLICATION TAG field. 

[i] If multiple errors occur, the selection of which error to report is not defined by this manual. 

ij 


oo 


If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to the lower 4 bytes of 
the LBA associated with the logical block. If type 2 protection or type 3 protection is enabled, the device server checks the 
logical block reference tag if it has knowledge of the contents of the logical block reference tag field. If type 2 protection is 
enabled, then this knowledge may be acquired through the expected initial logical block reference tag field in a WRITE (32), 
WRITE ATOMIC (32), WRITE SAME (32), or a WRITE STREAM (32) command. If type 3 protection is enabled, then the method for 
acquiring this knowledge is not defined by this manual. 
[k] If the NO_PI_CHK bit is set to one in the Extended INQUIRY Data VPD page (see 5.4.9) and the device server detects: 

a) aLOGICAL BLOCK APPLICATION TAG field set to FFFFh and type 1 protection or type 2 protection is enabled; or 

b) aLOGICAL BLOCK APPLICATION TAG field set to FFFFh, LOGICAL BLOCK REFERENCE TAG field set to FFFF_FFFFh, and type 

3 protection is enabled, 

then the device server shall not check any protection information in the associated protection information interval. 
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FUA bit 
0 A Force unit Access (FUA) bit set to zero specifies that the device server shall write the logical blocks to volatile cache (if any), non-vola- 
tile cache (if any), or the medium. 


1 An FUA bit set to one specifies that the device server shall write the logical blocks to non-volatile cache (if any) or the medium. 


If logical blocks are transferred directly to a cache, the device server may return GOOD status prior to writing the logical blocks to 
the medium. Any error that occurs after the GOOD status is returned is a deferred error, and information regarding the error is 
not reported until a subsequent command. 


TRANSFER LENGTH field 


The TRANSFER LENGTH field specifies the number of contiguous logical blocks of data that shall be transferred from the data-out buffer and 
written, starting with the logical block specified by the LOGICAL BLOCK ADDRESS field. A TRANSFER LENGTH field set to zero specifies that no 
logical blocks shall be written. This condition shall not be considered an error. Any other value specifies the number of logical blocks that shall 
be written. If the logical block address plus the transfer length exceeds the capacity of the medium, the device server shall terminate the com- 
mand with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK 
ADDRESS OUT OF RANGE. The TRANSFER LENGTH field is constrained by the MAXIMUM TRANSFER LENGTH field in the Block Limits VPD page. 


RWWP interaction 


If the device server has knowledge of the contents of the LOGICAL BLOCK APPLICATION TAG field and the ATO bit is set to one in 
the Control mode page (see SPC-5), then the device server: 


a) may check each logical block application tag if the RWWP bit is set to zero in the Control mode page (see SPC-5); and 
b) shall check each logical block application tag if the RWWP bit is set to one in the Control mode page. 
If the ATO bit in the Control mode page (see SPC-5) is set to one, then this knowledge is acquired from: 


a) the EXPECTED LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in the CDB, 
if a WRITE(32) command (see 3.63), a WRITE ATOMIC (32) command (see 3.69), a WRITE SAME (32) command (see 3.75), or 
a WRITE STREAM (32) command (see 3.77) is received by the device server; 

b) the EXPECTED LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in each LBA 
range descriptor, if a WRITE SCATTERED (32) command (see SBC-A4), is received by the device server; 

c) the Application Tag mode page (see 5.3.6), if a command other than WRITE(32), WRITE ATOMIC (32), WRITE SAME (32), 
WRITE SCATTERED(32), or WRITE STREAM (32) is received by the device server and the ATMPE bit in the Control mode page 
(see SPC-5) is set to one; or 

d) amethod not defined by this standard, if a command other than WRITE(32), WRITE ATOMIC (32), WRITE SAME (32), WRITE 
SCATTERED(32), or WRITE STREAM (32) is received by the device server, and the ATMPE bit is set to zero. 
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The WRITE (12) command (see table 218) requests that the device server transfer the specified logical block(s) from the data-out 
buffer and write them. Each logical block transferred includes user data and may include protection information, based on the 
WRPROTECT field and the medium format. Each logical block written includes user data and, if the medium is formatted with 
protection information enabled, protection information. 


Table 218 WRITE(12) command 




































































Bit 7 6 4 3 2 1 0 
Byte 

0 OPERATION CODE (AAh) 

1 WRPROTECT DPO FUA Reserved Obsolete Obsolete 
2 (MSB) 

LOGICAL BLOCK ADDRESS 
5 (LSB) 
6 (MSB) 
TRANSFER LENGTH 

9 (LSB) 
10 are for Reserved GROUP NUMBER 
11 CONTROL 








See the WRITE (10) command (see 3.60) for the definitions of the fields in this command. 
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WRITE (16) command 


Direct Access Block commands (SPC-5 and SBC-4) 


The WRITE (16) command (see table 219) requests that the device server transfer the specified logical block(s) from the data-out 
buffer and write them. Each logical block transferred includes user data and may include protection information, based on the 
WRPROTECT field and the medium format. Each logical block written includes user data and, if the medium is formatted with 
protection information enabled, protection information. 


Table 219 WRITE(16) command 

































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (8Ah) 
1 WRPROTECT DPO FUA Reserved Obsolete DLD2 
2 (MSB) 
LOGICAL BLOCK ADDRESS 
9 (LSB) 
10 (MSB) 
TRANSFER LENGTH 
13 (LSB) 
14 DLD1 DLDO GROUP NUMBER 
15 CONTROL 








See the READ (16) command (see 3.18) for the definitions of the DLD2 bit, the DLD1 bit, and the DLDO bit. 
See the WRITE (10) command (see 3.60) for the definitions of the other fields in this command. 
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3.63 


WRITE (32) command 


Direct Access Block commands (SPC-5 and SBC-4) 


The WRITE (32) command (see table 220) requests that the device server transfer the specified logical block(s) from the data-out 
buffer and write them. Each logical block transferred includes user data and may include protection information, based on the 
WRPROTECT field and the medium format. Each logical block written includes user data and, if the medium is formatted with 
protection information enabled, protection information. 


The WRITE (32) command shall only be processed if type 2 protection is enabled (see SBC-4). 


Table 220 WRITE (32) command 














































































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (7Fh) 

1 CONTROL 

2 
shore Reserved 

5 

6 Reserved GROUP NUMBER 

7 ADDITIONAL CDB LENGTH (18h) 

8 (MSB) 

SERVICE ACTION (OOOBh) 

9 (LSB) 
10 WRPROTECT DPO FUA Reserved Obsolete Reserved 
11 Reserved 
12 (MSB) 
sieve LOGICAL BLOCK ADDRESS 
19 (LSB) 
20 (MSB) 
ace EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 
23 (LSB) 
24 (MSB) 

EXPECTED LOGICAL BLOCK APPLICATION TAG 
25 (LSB) 
26 (MSB) 
LOGICAL BLOCK APPLICATION TAG MASK 

27 (LSB) 
28 (MSB) 
Sac TRANSFER LENGTH 
31 (LSB) 
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See the WRITE (10) command (see 3.60) for the definitions of the GROUP NUMBER field, the WRPROTECT field, the DPO bit, the 
FUA bit, the LOGICAL BLOCK ADDRESS field, and the TRANSFER LENGTH field. 


When checking of the LOGICAL BLOCK REFERENCE TAG field is enabled (see table 217 in 3.60), the EXPECTED INITIAL LOGICAL 
BLOCK REFERENCE TAG field contains the value of the LOGICAL BLOCK REFERENCE TAG field expected in the protection 
information of the first logical block accessed by the command instead of a value based on the LBA. 


If the ATO bit is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK APPLICATION TAG field is 
enabled (see table 217 in 3.60), the LOGICAL BLOCK APPLICATION TAG MASK field contains a value that is a bit mask for enabling 
the checking of the LOGICAL BLOCK APPLICATION TAG field in the protection information for each logical block accessed by the 
command. A LOGICAL BLOCK APPLICATION TAG MASK bit set to one enables the checking of the corresponding bit of the 
EXPECTED LOGICAL BLOCK APPLICATION TAG field with the corresponding bit of the LOGICAL BLOCK APPLICATION TAG field in 
the protection information. 


LOGICAL BLOCK APPLICATION TAG MASK and EXPECTED LOGICAL BLOCK APPLICATION TAG fields 


The LOGICAL BLOCK APPLICATION TAG MASK field and the EXPECTED LOGICAL BLOCK APPLICATION TAG field shall be ignored if: 


a) the ATO bit is set to zero; or 
b) the ATO bit is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK APPLICATION TAG field is disabled 
(see SBC-4). 
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3.64 WRITE AND VERIFY (10) command 


The WRITE AND VERIFY (10) command (see table 221) requests that the device server transfer the specified logical block(s) from 
the data-out buffer, write them to the medium, and then verify that they are correctly written. Each logical block includes user 
data and may include protection information, based on the WRPROTECT field and the medium format. The logical blocks are 
only transferred once from the data-out buffer to the device server. 


Table 221 WRITE AND VERIFY (10) command 





















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (2Eh) 
1 WRPROTECT DPO Reserved BYTCHK Obsolete 
2 (MSB) 

LOGICAL BLOCK ADDRESS 
5 (LSB) 
6 Reserved GROUP NUMBER 
7 (MSB) 

TRANSFER LENGTH 

8 (LSB) 
9 CONTROL 











See 2.2.3 for the definition of the LOGICAL BLOCK ADDRESS field. See 2.2.8 for the definition of the GROUP NUMBER field. See the 
WRITE (10) command (see 3.60) for the definitions of the TRANSFER LENGTH field and the WRPROTECT field. See the READ (10) 
command (see 3.16) for the definition of the DPO bit. 


If the Verify Error Recovery mode page is also implemented, then the current settings in that mode page along with the AWRE bit 
in the Read-Write Error Recovery mode page specify the verification error criteria. If these mode pages are not implemented, 
then the verification criteria is vendor-specific. 


See the VERIFY (10) command for the definition of the byte check (BYTCHK) field when set to 00b, 01b, or 10b. For WRITE AND 
VERIFY commands a BYTCHK field set to 11b is reserved. 
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3.65 


Direct Access Block commands (SPC-5 and SBC-4) 


WRITE AND VERIFY (12) command 


The WRITE AND VERIFY (12) command (see table 222) requests that the device server transfer the specified logical block(s) from 
the data-out buffer, write them to the medium, and then verify that they are correctly written. Each logical block includes user 
data and may include protection information, based on the WRPROTECT field and the medium format. The logical blocks are 
only transferred once from the data-out buffer to the device server. 






























































Table 222 WRITE ANDVERIFY (12) command 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (AEh) 
1 WRPROTECT DPO Reserved BYTCHK Obsolete 
2 (MSB) 
LOGICAL BLOCK ADDRESS 
5 (LSB) 
6 (MSB) 
TRANSFER LENGTH 
9 (LSB) 
10 eee for Reserved GROUP NUMBER 
11 CONTROL 














See the WRITE AND VERIFY (10) command (see 3.64) for the definitions of the fields in this command. 


SCSI Commands Reference Manual, Rev. J 


258 


www.seagate.com 


3.66 


Direct Access Block commands (SPC-5 and SBC-4) 


WRITE AND VERIFY (16) command 


The WRITE AND VERIFY (16) command (see table 223) requests that the device server transfer the specified logical block(s) from 
the data-out buffer, write them to the medium, and then verify that they are correctly written. Each logical block includes user 
data and may include protection information, based on the WRPROTECT field and the medium format. The logical blocks are 
only transferred once from the data-out buffer to the device server. 






























































Table 223. WRITE AND VERIFY (16) command 

Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (8Eh) 

1 WRPROTECT DPO Reserved BYTCHK Reserved 

2 (MSB) 

LOGICAL BLOCK ADDRESS 

9 (LSB) 

10 (MSB) 
TRANSFER LENGTH 

13 (LSB) 
14 ee fot Reserved GROUP NUMBER 

15 CONTROL 














See the WRITE AND VERIFY (10) command (see 3.64) for the definitions of the fields in this command. 
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3.67 


Direct Access Block commands (SPC-5 and SBC-4) 


WRITE AND VERIFY (32) command 


The WRITE AND VERIFY (32) command (see table 224) requests that the device server transfer the specified logical block(s) from 
the data-out buffer, write them to the medium, and then verify that they are correctly written. Each logical block includes user 
data and may include protection information, based on the WRPROTECT field and the medium format. The logical blocks are 
only transferred once from the data-out buffer to the device server. 





































































































Table 224 WRITE AND VERIFY (32) command 
Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (7Fh) 

1 CONTROL 

2 

Reserved 

5 

6 Reserved GROUP NUMBER 

7 ADDITIONAL CDB LENGTH (18h) 

8 (MSB) 

SERVICE ACTION (000Ch) 

9 (LSB) 
10 WRPROTECT DPO Reserved BYTCHK Reserved 
11 Reserved 

12 (MSB) 

LOGICAL BLOCK ADDRESS 
19 (LSB) 
20 (MSB) 
EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 
23 (LSB) 
24 (MSB) 
EXPECTED LOGICAL BLOCK APPLICATION TAG 
25 (LSB) 
26 (MSB) 
LOGICAL BLOCK APPLICATION TAG MASK 
27 (LSB) 
28 (MSB) 
TRANSFER LENGTH 

31 (LSB) 
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See the WRITE AND VERIFY (10) command (see 3.64) for the definitions of the GROUP NUMBER field, the WRPROTECT field, the 
DPO bit, the BYTCHK field, the LOGICAL BLOCK ADDRESS field, and the TRANSFER LENGTH field. 


When checking of the LOGICAL BLOCK REFERENCE TAG field is enabled (see table 217), the EXPECTED INITIAL LOGICAL BLOCK 
REFERENCE TAG field contains the value of the LOGICAL BLOCK REFERENCE TAG field expected in the protection information of 
the first logical block accessed by the command instead of a value based on the LBA. 


If the ATO bit is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK APPLICATION TAG field is 
enabled (see table 217), the LOGICAL BLOCK APPLICATION TAG MASK field contains a value that is a bit mask for enabling the 
checking of the LOGICAL BLOCK APPLICATION TAG field in the protection information for each logical block accessed by the 
command. A LOGICAL BLOCK APPLICATION TAG MASK bit set to one enables the checking of the corresponding bit of the 
EXPECTED LOGICAL BLOCK APPLICATION TAG field with the corresponding bit of the LOGICAL BLOCK APPLICATION TAG field in 
the protection information. 


If the ATO bit is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK APPLICATION TAG field is 
disabled (see table 217), or if the ATO bit is set to zero, the LOGICAL BLOCK APPLICATION TAG MASK field and the EXPECTED 
LOGICAL BLOCK APPLICATION TAG field shall be ignored. 
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3.68 WRITE ATOMIC (16) command 


The WRITE ATOMIC (16) command (see table 225) requests that the device server. 


a) transfer logical block data from the Data-Out Buffer; and 
b) perform one or more atomic write operations (see SBC-4) of the LBAs specified by this command. 


Table 225 WRITE ATOMIC (16) command 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (9Ch) 

1 WRPROTECT DPO FUA Reserved 

2 (MSB) 

‘ LOGICAL BLOCK ADDRESS 

9 (LSB) 
10 
1 ATOMIC BOUNDARY 
12 (MSB) 

TRANSFER LENGTH ———-F 

13 (LSB) 
14 Reserved GROUP NUMBER 
15 CONTROL 














OPERATION CODE field 

The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the value defined in 
table 225 for the WRITE ATOMIC (16) command. 

ATOMIC BOUNDARY field 


The ATOMIC BOUNDARY field specifies whether multiple atomic write operations may be performed. If the ATOMIC BOUNDARY field is set to 
zero, then a single atomic write operation of the length specified in the TRANSFER LENGTH field shall be performed. If the ATOMIC BOUNDARY 
field is set to a non-zero value then multiple atomic write operations may be performed as described in SBC-4. 


See the WRITE (10) command (see 3.60) for the definitions of the other fields in this command. 
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3.69 WRITE ATOMIC (32) command 


The WRITE ATOMIC (32) command (see table 226) requests that the device server perform the actions defined for the WRITE 
ATOMIC (16) command (see 3.68). 


The device server shall process a WRITE ATOMIC (32) command only if type 2 protection is enabled. 


Table 226 WRITE ATOMIC (32) command 





























































































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (7Fh) 
1 CONTROL 
2 

Reserved 
3 
4 (MSB) 

ATOMIC BOUNDARY 
5 (LSB) 
6 Reserved GROUP NUMBER 
7 ADDITIONAL CDB LENGTH (18h) 
8 (MSB) 
SERVICE ACTION (OOOFh) 
9 (LSB) 
10 WRPROTECT DPO FUA Reserved Obsolete Reserved 
11 Reserved 
12 (MSB) 
LOGICAL BLOCK ADDRESS 
19 (LSB) 
20 (MSB) 
EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 
23 (LSB) 
24 (MSB) 
EXPECTED LOGICAL BLOCK APPLICATION TAG | 
25 (LSB) 
26 (MSB) 
LOGICAL BLOCK APPLICATION TAG MASK 
27 (LSB) 
28 (MSB) 
TRANSFER LENGTH 

31 (LSB) 





OPERATION CODE, ADDITIONAL CDB LENGTH, and SERVICE ACTION fields 


The Operation Code field, the Additional CDB Length field, and the Service Action field are defined in Clause 2.2 and shall be set 
to the values shown in table 226 for the WRITE ATOMIC (32) command. 


See the WRITE ATOMIC (16) command (see 3.68) for the definition of the ATOMIC BOUNDARY field. 


See the WRITE (32) command (see 3.63) for the definitions of the other fields in this command. 
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3.70 WRITE BUFFER command 


3.70.1 WRITE BUFFER command introduction 
The WRITE BUFFER command (see table 227) is used in conjunction with the READ BUFFER command for: 


a 


) testing logical unit buffer memory; 

) testing the integrity of the service delivery subsystem; 

) downloading microcode; and 

d) downloading application client error history (see SPC-5). 


at 


Table 227 WRITE BUFFER command 
























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (3Bh) 
1 MODE SPECIFIC MODE 
2 BUFFER ID 
3 (MSB) 
BUFFER OFFSET 
(LSB) 
6 (MSB) 
PARAMETER LIST LENGTH 
(LSB) 
CONTROL 








This command shall not alter any medium of the logical unit when the data mode or the combined header and data mode is 
specified. 
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The function of this command and the meaning of fields within the CDB depend on the contents of the MODE field. The MODE 
field is defined in table 228. 


Table 228 WRITE BUFFER MODE field 






























































Mode Description 
00h Combined header and data [a] 
O1h Not supported 
02h Data 
04h Download microcode and activate 
05h Download microcode, save and activate 
06h Download microcode with offsets [b] and activate 
07h Download microcode with offsets [b], save, and activate 
08h - 09h Reserved 
OAh Echo buffer 
OBh - OCh Reserved 
ODh Download microcode with offsets, select activation events, save, and defer activate 
OEh Download microcode with offsets, save, and defer active 
OFh Activate deferred microcode 
10h - 19h Reserved 
1Ah Enable expander communications protocol and Echo buffer 
1Bh Disable expander communications protocol 
1Ch Download application log 
1Dh-1Fh Reserved 








[a] Mode 00h is not recommended. 
[b] When downloading microcode with buffer offsets, the WRITE BUFFER command mode should be 06h or 07h. 
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3.70.2 Combined header and data mode (00h) 
NOTE _ This mode is not recommended. 


In this mode, data to be transferred is preceded by a four-byte header. The four-byte header consists of all reserved bytes. The 
BUFFER ID and the BUFFER OFFSET fields shall be zero. 


The MODE SPECIFIC field is reserved. 


The PARAMETER LIST LENGTH field specifies the maximum number of bytes that shall be transferred from the Data-Out Buffer. 
This number includes four bytes of header, so the data length to be stored in the device server's buffer is parameter list length 
minus four. The application client should attempt to ensure that the parameter list length is not greater than four plus the 
BUFFER CAPACITY field value (see table 106) that is returned in the header of the READ BUFFER command (mode Oh). If the 
parameter list length exceeds the buffer capacity, the command shall be terminated with CHECK CONDITION status, with the 
sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


3.70.3 Vendor specific mode (01h) 


This mode is not supported by Seagate products. If used, the drive will return CHECK CONDITION and report an ILLEGAL 
REQUEST/INVALID FIELD IN CDB error. 


3.70.4 Data mode (02h) 


In this mode, the Data-Out Buffer contains buffer data destined for the logical unit. The BUFFER ID field identifies a specific buffer 
within the logical unit. Seagate assigns buffer ID codes to buffers within the logical unit. Buffer ID zero shall be supported. If 
more than one buffer is supported, then additional buffer ID codes shall be assigned contiguously, beginning with one. If an 
unsupported buffer ID code is selected, the command shall be terminated with CHECK CONDITION status, with the sense key set 
to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


The MODE SPECIFIC field is reserved. 


Data are written to the logical unit buffer starting at the location specified by the BUFFER OFFSET field. The application client should 
conform to the offset boundary requirements returned in the READ BUFFER descriptor. If the device server is unable to accept 
the specified buffer offset, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


The PARAMETER LIST LENGTH field specifies the maximum number of bytes that shall be transferred from the Data-Out Buffer to 
be stored in the specified buffer beginning at the buffer offset. The application client should attempt to ensure that the 
parameter list length plus the buffer offset does not exceed the capacity of the specified buffer. The capacity of the buffer is 
indicated by the BUFFER CAPACITY field in the READ BUFFER descriptor (see table 106). If the BUFFER OFFSET and PARAMETER 
LIST LENGTH fields specify a transfer in excess of the buffer capacity, the command shall be terminated with CHECK CONDITION 
status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


3.70.5 Download microcode and activate mode (04h) 
In this mode, microcode shall be transferred to the device server and activated (see SPC-5). 
The MODE SPECIFIC field is reserved. 
The BUFFER ID field, BUFFER OFFSET field, and PARAMETER LIST LENGTH field are vendor specific. 


3.70.6 Download microcode, save, and activate mode (05h) 


In this mode, microcode shall be transferred to the device server, saved to nonvolatile storage, and activated (see 5.4) based on 
the setting of the ACTIVATE MICROCODE field in the Extended INQUIRY VPD page (see 5.4.9). 


The MODE SPECIFIC field is reserved. 
The BUFFER ID field, BUFFER OFFSET field, and PARAMETER LIST LENGTH field are vendor specific. 
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3.70.7 Download microcode with offsets and activate mode (06h) 


In this mode, microcode shall be transferred to the device server using one or more WRITE BUFFER commands and activated (see 
SPC-5). 


The MODE SPECIFIC field is reserved. 


The BUFFER ID field specifies a buffer within the logical unit. The vendor assigns buffer ID codes to buffers within the logical unit. 
A buffer ID value of zero shall be supported. If more than one buffer is supported, then additional buffer ID codes shall be 
assigned contiguously, beginning with one. If an unsupported buffer ID code is specified, the command shall be terminated with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN 
CDB. 


The BUFFER OFFSET field specifies the location in the buffer to which the microcode is written. The application client shall send 
commands that conform to the offset boundary requirements returned in the READ BUFFER descriptor (see table 106). If the 
device server is unable to process the specified buffer offset, the command shall be terminated with CHECK CONDITION status, 
with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


The PARAMETER LIST LENGTH field specifies the maximum number of bytes that shall be present in the Data-Out Buffer to be 
stored in the specified buffer beginning at the buffer offset. The application client should ensure that the parameter list length 
plus the buffer offset does not exceed the capacity of the specified buffer. If the BUFFER OFFSET and PARAMETER LIST LENGTH 
fields specify a transfer in excess of the buffer capacity, then the command shall be terminated with CHECK CONDITION status, 
with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


3.70.8 Download microcode with offsets and save mode (07h) 


In this mode, microcode shall be transferred to the device server using one or more WRITE BUFFER commands, saved to 
nonvolatile storage, and activated (see 5.4) based on the setting of the ACTIVATE MICROCODE field in the Extended INQUIRY VPD 
page (see 5.4.9). 


The BUFFER ID field, BUFFER OFFSET field, and PARAMETER LIST LENGTH field are defined in the download microcode with 
offsets mode (see 3.70.7). 


3.70.9 Write data to echo buffer mode (OAh) 


In this mode the device server transfers data from the application client and stores it in an echo buffer. An echo buffer is assigned 
in the same manner by the device server as it would for a write operation. Data shall be sent aligned on four-byte boundaries. 
The BUFFER ID and BUFFER OFFSET fields are ignored in this mode. 


Upon successful completion of a WRITE BUFFER command the data shall be preserved in the echo buffer unless there is an 
intervening command to any logical unit in which case the data may be changed. 


The PARAMETER LIST LENGTH field specifies the maximum number of bytes that shall be transferred from the Data-Out Buffer to 
be stored in the echo buffer. The application client should ensure that the parameter list length does not exceed the capacity of 
the echo buffer. The capacity of the echo buffer is indicated by the BUFFER CAPACITY field in the READ BUFFER echo buffer 
descriptor (see Table 108). If the PARAMETER LIST LENGTH field specifies a transfer in excess of the buffer capacity, the command 
shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 
set to INVALID FIELD IN CDB. 
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3.70.10 Download microcode with offsets, select activation events, save, and defer activate mode (ODh) 


In this mode, microcode shall be transferred to the device server using one or more WRITE BUFFER commands, saved to 
nonvolatile storage, and considered deferred (see SPC-5). The deferred microcode shall be activated and no longer considered 
deferred if a WRITE BUFFER command with the activate deferred microcode mode (OFh) is processed (see 3.70.12). 


The MODE SPECIFIC field (see table 229) specifies additional events that shall be used to activate the deferred microcode. 


Table 229 MODE SPECIFIC field 





Bit 7 6 5 





PO_ACT HR_ACT VSE_ACT 























If the power on activate (PO_ACT) bit is set to one, then deferred microcode shall be activated and no longer considered 
deferred if a power on occurs. If the PO_ACT bit is set to zero, then deferred microcode shall not be activated if a power on 
occurs. 


If the hard reset activate (HR_ACT) bit is set to one, then deferred microcode shall be activated and no longer considered 
deferred if a hard reset occurs. If the HR_ACT bit is set to zero, then deferred microcode shall not be activated if a hard reset 
occurs. 


If the vendor specific event activate (VSE_ACT) bit is set to one, then deferred microcode shall be activated and no longer 
considered deferred if a vendor specific event occurs. If the VSE_ACT bit is set to zero, then deferred microcode shall not be 
activated if a vendor specific event occurs. 


The supported activation events shall be reported in the POA_SUP bit, HRA_SUP bit, and VSA_SUP bit in the Extended INQUIRY 
VPD page (see 5.4.9). If the MODE SPECIFIC field specifies an activation event that is not supported (e.g., if the PO_ACT bit is set 
to one and the POA_SUP bit is set to zero), then the command shall be terminated with CHECK CONDITION status with the sense 
key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 


The BUFFER ID field, BUFFER OFFSET field, and PARAMETER LIST LENGTH field are defined in the download microcode with 
offsets mode (see 3.70.7). 


3.70.11 Download microcode with offsets, save, and defer activate mode (OEh) 


In this mode, microcode shall be transferred to the device server using one or more WRITE BUFFER commands, saved to 
nonvolatile storage, and considered deferred (see SPC-5). 


The deferred microcode should be activated and no longer considered deferred if any one of the following occurs: 


a) apower on; 

b) ahard reset; 

c) aSTART STOP UNIT command is processed (see 3.49); 

d) aFORMAT UNIT command is processed (see 3.3); or 

e) aWRITE BUFFER command with the activate deferred microcode mode (0Fh) is processed (see 3.70.12). 


NOTE Seagate products only support deferred microcode activation on event e 
(i.e.,a WRITE BUFFER command with MODE field set to OFh). 


The MODE SPECIFIC field, BUFFER ID field, BUFFER OFFSET field, and PARAMETER LIST LENGTH field are defined in the download 
microcode with offsets mode (see 3.70.7). 
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3.70.12 Activate deferred microcode mode (OFh) 


In this mode, deferred microcode that has been saved using the download microcode with offsets, select activation events, save, 
and defer activate (see 3.70.10) or download microcode with offsets, save, and defer activate mode (see 3.70.11), if any, shall be 
activated and no longer considered deferred (see SPC-5). 


The MODE SPECIFIC field is reserved. 
The the BUFFER ID field, BUFFER OFFSET field, and PARAMETER LIST LENGTH field shall be ignored in this mode. 


If there is no deferred microcode that has been saved using the download microcode with offsets, save, and defer activate mode, 
then the WRITE BUFFER command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to COMMAND SEQUENCE ERROR. 


3.70.13 Enable expander communications protocol and Echo buffer mode (1Ah) 


Receipt of a WRITE BUFFER command with this mode (1Ah) causes a communicative expander to enter the expanded 
communications protocol mode. Device servers in SCSI target devices that receive a WRITE BUFFER command with this mode 
shall process it as if it were a WRITE BUFFER command with mode OAh (see 3.70.9). 


The MODE SPECIFIC field is reserved. 


3.70.14 Disable expander communications protocol mode (1Bh) 


Receipt of a WRITE BUFFER command with this mode (1Bh) causes a communicative expander to exit the expanded 
communications protocol mode and return to simple expander operation. Device servers in SCSI target devices that receive a 
WRITE BUFFER command with this mode shall terminate the command with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


The MODE SPECIFIC field is reserved. 
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3.70.15 Download application log mode (1Ch) 


In this mode the device server transfers data from the application client and stores it in an application log. The format of the 
application log data is as specified in table 230. 


The MODE SPECIFIC field is reserved. 
The BUFFER ID field and BUFFER OFFSET field are ignored in this mode. 


Upon successful completion of a WRITE BUFFER command, the information contained in the application client error history 
parameter list shall be appended to the application client error history in a format determined by the logical unit. 


The PARAMETER LIST LENGTH field specifies the maximum number of bytes that shall be transferred from the Data-Out Buffer to 
be stored in the application log. If the PARAMETER LIST LENGTH field specifies a transfer that exceeds the application log’s 
capacity, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the 
additional sense code set to INVALID FIELD IN CDB 


The device server shall not return an error based on the contents of any of the field values defined in table 230 except: 


a) the CLR bit; 
b) the ERROR LOCATION LENGTH field; and 
c) the APPLICATION CLIENT ERROR HISTORY LENGTH field. 


Table 230 Application log data WRITE BUFFER format 




























































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
T10 VENDOR IDENTIFICATION 
7 (LSB) 
8 (MSB) 
ERROR TYPE S| 
9 (LSB) 
10 Reserved CLR 
11 Reserved 
12 (MSB) 
vee TIME STAMP 
17 (LSB) 
18 
Reserved 
19 
20 Reserved CODE SET 
21 ERROR LOCATION FORMAT 
22 (MSB) 
ERROR LOCATION LENGTH (m-25) S| 
23 (LSB) 
24 (MSB) 
APPLICATION CLIENT ERROR HISTORY LENGTH (n-m) ——_—_ 
25 (LSB) 
26 (MSB) 
ERROR LOCATION 
m (LSB) 
m+1 





APPLICATION CLIENT ERROR HISTORY 
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T10 VENDOR IDENTIFICATION field 


The T10 VENDOR IDENTIFICATION field contains eight bytes of left-aligned ASCII data identifying the vendor of the product. The T10 vendor 
identification shall be one assigned by INCITS. A list of assigned T10 vendor identifications is in SPC-5 and on the T10 web site 


(http://www.T10.org). 
ERROR TYPE field 
The ERROR TYPE field (see table 231) specifies the error detected by the application client. 


Table 231 ERRORTYPE field 





























Code Description 

0000h No error specified by the application client 

0001h An unknown error was detected by the application client 

0002h The application client detected corrupted data 

0003h The application client detected a permanent error 

0004h The application client detected a service response of SERVICE DELIVERY OR TARGET FAILURE (SAM-5). 
0005h-7FFFh | Reserved 
8000h-FFFFh | Vendor specific 


CLR bit 


If the CLR_SUP bit is set to one in the error history directory parameter data (see 3.70.15), a CLR bit set to one specifies that the 
device server shall: 


a) clear the portions of the error history that the device server allows to be cleared; and 
b) ignore any application client error history specified in the parameter list. 


If the CLR_SUP bit is set to one in the error history directory parameter data, a CLR bit set to zero specifies that the device server 
shall not ignore the CLR bit. 


If the CLR_SUP bit is set to one in the error history directory parameter data, a CLR bit set to zero specifies that the device server 
shall: 


a) not clear the error history; and 
b) process all application client error history specified in the parameter list. 


If the CLR_SUP bit is set to zero in the error history directory parameter data, the device server shall ignore the CLR bit. 


TIME STAMP field 
The TIME STAMP field shall contain: 


a) a time based on the timestamp reported by the REPORT TIMESTAMP command, if the device server supports a device 
clock (see SPC-5) 

b) The number of milliseconds that have elapsed since midnight, 1 January 1970 UT; or 

c) Zero, if the application client is not able to determine the UT of the log entry. 
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CODE SET field 


The CODE SET field specifies the code set used for the application log information (see table 232) and shall only apply to information contained 
in the VENDOR SPECIFIC field. 


Table 232 CODE SET field 























Code Description 
Oh Reserved 
th The application log information is binary 
2h The application log information is ASCII printable characters (i.e., code values 20h through 7Eh) 
3h The application log information is ISO/IEC 10646-1 (UTF-8) codes 
4h-Fh Reserved 











ERROR LOCATION FORMAT field 
The ERROR LOCATION FORMAT field specifies the format (see table 233) of the ERROR LOCATION field. 


Table 233. ERROR LOCATION FORMAT field 


Code Description 
00h No error specified by the application client 


The ERROR LOCATION field specifies the logical block (e.g., LBA) associated with the error information contained 


mn within the application log. 





02h-7Fh | Reserved 








80h-FFh | Vendor specific 











ERROR LOCATION LENGTH field 


The ERROR LOCATION LENGTH field specifies the length of the ERROR LOCATION field. The ERROR LOCATION LENGTH field value shall be a mul- 
tiple of four. An error location length value of zero specifies there is no error location information. 


APPLICATION CLIENT ERROR HISTORY LENGTH field 


The APPLICATION CLIENT ERROR HISTORY LENGTH field specifies the length of the APPLICATION CLIENT ERROR HISTORY field. The APPLICA- 
TION CLIENT ERROR HISTORY LENGTH field value shall be a multiple of four. A vendor specific length value of zero specifies there is no vendor 
specific information. 


ERROR LOCATION field 
The ERROR LOCATION field specifies the location at which the application client detected the error. 


APPLICATION CLIENT ERROR HISTORY field 
The APPLICATION CLIENT ERROR HISTORY field provides vendor specific information on the error. 
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3.71 WRITE LONG (10) command 


The WRITE LONG (10) command (see table 234) requests that the device server mark a logical block or physical block as 
containing an error, or transfer data for a single logical block from the data-out buffer and write it to the medium. The data 
written shall be the same length and shall be in the same order as the data returned by the READ LONG (10) command (see 3.26). 
The device server shall write the logical block to the medium, and shall not return GOOD status until the logical block has 
actually been written on the medium without error. 


Table 234 WRITELONG (10) command 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (3Fh) 
1 Obsolete WR_UNCOR Obsolete Reserved Obsolete 
2 (MSB) 

LOGICAL BLOCK ADDRESS 
5 (LSB) 
6 Reserved 
7 (MSB) 

BYTE TRANSFER LENGTH 

8 (LSB) 
9 CONTROL 











OPERATION CODE field 
The OPERATION CODE field contains the operation code for this command and shall be set to the value defined in table 234. 


WR_UNCOR bit 
0 Obsolete 


1 Mark the specified logical block as containing a pseudo unrecovered error with correction disabled (see SBC-4). 
No data is transferred. 


In the Extended INQUIRY Data VPD page (see 5.4.9), the WU_SUP bit shall be set to one if the WRITE LONG command is 
supported. 


LOGICAL BLOCK ADDRESS field 


The LOGICAL BLOCK ADDRESS field (see 2.2.3) specifies an LBA. If the specified LBA exceeds the capacity of the medium, then the device server 
shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
LOGICAL BLOCK ADDRESS OUT OF RANGE 


BYTE TRANSFER LENGTH field 


If table 234 defines that the value in the BYTE TRANSFER LENGTH field is used, then the BYTE TRANSFER LENGTH field specifies the number of 
bytes of data that the device server shall transfer from the data-out buffer and write to the specified logical block or physical block. If the BYTE 
TRANSFER LENGTH field is not set to zero and does not match the data length that the device server returns for a READ LONG command, then 
the device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional 
sense code set to INVALID FIELD IN CDB. In the sense data (see 2.4), the ILI and VALID bits shall be set to one and the INFORMATION field shall 
be set to the difference (i.e., residue) of the requested length minus the actual length in bytes. Negative values shall be indicated by two's com- 
plement notation. If the BYTE TRANSFER LENGTH field is set to zero, then no bytes shall be written. This condition shall not be considered an 
error. 
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WRITE LONG (16) command 


3.72 


The WRITE LONG (16) command (see table 235) requests that the device server mark a logical block or physical block as 
containing an error, or transfer data for a single logical block from the data-out buffer and write it to the medium. The data 
written shall be the same length and shall be in the same order as the data returned by the READ LONG (16) command (see 3.27). 
The device server shall write the logical block to the medium, and shall not return GOOD status until the logical block has been 
written on the medium without error. This command is implemented as a service action of the SERVICE ACTION OUT operation 


















































code. 
Table 235 WRITELONG (16) command 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 OPERATION CODE (9Fh) 
1 Obsolete WR_UNCOR Obsolete SERVICE ACTION (11h) 
2 (MSB) 
LOGICAL BLOCK ADDRESS 
9 (LSB) 
10 
Reserved 
11 
12 (MSB) 
BYTE TRANSFER LENGTH 
13 (LSB) 
14 Reserved 
15 CONTROL 














OPERATION CODE and SERVICE ACTION fields 
The OPERATION CODE field (see 2.2.1) and SERVICE ACTION field (see 2.2.2) shall be set to the values defined in table 235. 


OPERATION CODE field 


The OPERATION CODE field contains the operation code of a command supported by the logical unit and shall be set to the 
value defined in table 235. 


See the WRITE LONG (10) command (see 3.71) for the definitions of the fields in this command. 
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3.73 WRITE SAME (10) command 


The WRITE SAME(10) command (see table 236) requests that the device server transfer a single logical block from the Data-Out 
Buffer and for each LBA in the specified range of LBAs: 

a) perform a write operation using the contents of that logical block; or 

b) perform an unmap operation. 
The device server writes (i.e, subsequent read operations behave as if the device server wrote the single block of user data 
received from the Data-Out Buffer to each logical block without modification (see SBC-4). 


If the medium is formatted with protection information and the WRPROTECT field is set to 000b, then the device server shall 
write the LOGICAL BLOCK GUARD field, APPLICATION TAG field, and LOGICAL BLOCK REFERENCE TAG field (see4.22) for each 
logical block as described in table119 (i.e., code equal to 000b row of table1 19). 


If: 


a) the medium is formatted with protection information; 

b) the WRPROTECT field is not set to 000b or a reserved value (seetable119); and 

c) the protection information from the Data-Out Buffer is set to FFFF_FFFF_FFFF_FFFFh, 
then the device server shall write FFFF_FFFF_FFFF_FFFFh to the protection information for each logical block. 
If: 

a) the medium is formatted with type 1 or type 2 protection information; 

b) the WRPROTECT field is not set to 000b or a reserved value (seetable119); and 

c) the protection information from the Data-Out Buffer is not set to FFFF_FFFF_FFFF_FFFFh, 
then: 


a) the device server shall write the value from the LOGICAL BLOCK REFERENCE TAG field (see4.22) received in the logical block from the 
Data-Out Buffer into the corresponding LOGICAL BLOCK REFERENCE TAG field of the first logical block written. The device sever shall 
write the value of the previous LOGICAL BLOCK REFERENCE TAG field plus one into each of the subsequent LOGICAL BLOCK REFERENCE 
TAG fields; 


b) if the ATO bit is set to one in the Control mode page (see SPC-5) and the and the ATMPE bit is set to zero in the Control mode page, then 
the device server shall write the logical block application tag received in the logical block from the Data-Out Buffer into the correspond- 
ing LOGICAL BLOCK APPLICATION TAG field (see4.22) of each logical block; 


c) _ if the ATO bit is set to one in the Control mode page and the and the ATMPE bit is set to zero in the Control mode page, then the device 
server shall write the value defined in the Application Tag mode page (see6.5.3) into the corresponding LOGICAL BLOCK APPLICATION 
TAG field of each logical block; 


d) if the ATO bit is set to zero in the Control mode page, then the device server may write any value into the LOGICAL BLOCK APPLICATION 
TAG field of each logical block; and 


e) the device server shall write the value from the LOGICAL BLOCK GUARD field (see4.22) received in the logical block from the Data-Out 
Buffer into the corresponding LOGICAL BLOCK GUARD field of each logical block. 


a) the medium is formatted with type 3 protection information; 
b) the WRPROTECT field is not set to 000b or a reserved value (seetable119); and 
c) the protection information from the Data-Out Buffer is not set to FFFF_FFFF_FFFF_FFFFh, 


a) if the ATO bit is set to one in the Control mode page (see SPC-5), then the device server shall write the value from the LOGICAL BLOCK 
REFERENCE TAG field and the LOGICAL BLOCK APPLICATION TAG field received in the logical block from the Data-Out Buffer into the 
corresponding LOGICAL BLOCK REFERENCE TAG field of each logical block; 

b) if the ATO bit is set to zero in the Control mode page, then the device server may write any value into the LOGICAL BLOCK REFERENCE 
TAG field of each logical block; and 

c) _ the device server shall write the value from the LOGICAL BLOCK GUARD field and the LOGICAL BLOCK APPLICATION TAG field received 
in the logical block from the Data-Out Buffer into the corresponding LOGICAL BLOCK GUARD field of each logical block. 
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Table 236 WRITE SAME (10) command 



























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (41h) 

1 WRPROTECT ANCHOR UNMAP Obsolete Obsolete Obsolete 
2 (MSB) 
ae LOGICAL BLOCK ADDRESS 

5 (LSB) 
6 Reserved GROUP NUMBER 

7 (MSB) 

NUMBER OF BLOCKS 

8 (LSB) 
9 CONTROL 











WRPROTECT field 
See the WRITE (10) command (see 3.60) for the definitions of the WRPROTECT field. 


LOGICAL BLOCK ADDRESS field 
See 2.2.3 for the definition of the LOGICAL BLOCK ADDRESS field. 


GROUP NUMBER field 
See clause 2.2.8 for the definition of the GROUP NUMBER field. 


SCSI Commands Reference Manual, Rev. J 276 


www.seagate.com Direct Access Block commands (SPC-5 and SBC-4) 


ANCHOR and UNMAP bits 


If the logical unit supports logical block provisioning management (see SBC-4), then the ANCHOR bit, the UNMAP bit, and the ANC_SUP bit in 
the Logical Block Provisioning VPD page (see 5.4.13) determine how the device server processes the command as described in Table 237. 


Table 237. ANCHOR bit, UNMAP bit, and ANC_SUP bit relationships 

















UNMAP bit #! ANCHOR bit ANC_SUP bit !>] Action 
bb n/a Write fl 
Ob 
1b n/a Error !4l 
up n/a Unmap !@! 
m 0 Error !4l 
1b 
1 Anchor Ff! 











[a] The device server in a logical unit that supports logical block provisioning management (see SBC-4) may implement the UNMAP bit. 
[b] See the Logical Block Provisioning VPD page (see 5.4.13). 

[c] The device server shall perform the specified write operation on each LBA specified by the command. 

[ 


d] The device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the addi- 
tional sense code set to INVALID FIELD IN CDB. 


[e] The device server in a thin provisioned logical unit should deallocate each LBA specified by the command (see SBC-4) but may anchor each 
LBA specified by the command (see SBC-4). The device server in a resource provisioned logical unit should anchor each LBA specified by 
the command. If the device server does not deallocate or anchor the LBA, then the device server shall perform the specified write opera- 
tion (see SBC-4). 


[f] The device server should anchor each LBA specified by the command (see SBC-4). If the device server does not anchor the LBA, then the 
device server shall perform the specified write operation (see SBC-4). 











NUMBER OF BLOCKS field 


The NUMBER OF BLOCKS field specifies the number of contiguous logical blocks to be written, starting with the logical block specified by the 
LOGICAL BLOCK ADDRESS field. A NUMBER OF BLOCKS field set to zero specifies that the device server write all the logical blocks starting with 
the one specified in the LOGICAL BLOCK ADDRESS field to the last logical block on the medium. If the logical block address plus the number of 
blocks exceeds the capacity of the medium, the device server shall terminate the command with CHECK CONDITION status with the sense key 
set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. 
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3.74 WRITE SAME (16) command 


The WRITE SAME (16) command (see table 238) requests that the device server transfer a single logical block from the data-out 
buffer and write the contents of that logical block to the specified range of logical block addresses. Each logical block includes 
user data and may include protection information, based on the WRPROTECT field and the medium format. The WRITE SAME 
(16) command with the UNMAP bit supported is one of the possible commands that shall be implemented by device servers 
supporting thin provisioning (see SBC-4). 


Table 238 WRITESAME (16) command 




































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (93h) 

1 WRPROTECT ANCHOR UNMAP Obsolete Obsolete NDOB 
2 (MSB) 

LOGICAL BLOCK ADDRESS 
9 (LSB) 
10 (MSB) 
aiaes, NUMBER OF BLOCKS 
13 (LSB) 
14 Reserved GROUP NUMBER 
15 CONTROL 
NDOB bit 


A NDOB bit set to zero specifies that the device server shall process the command using logical block data from the Data-Out Buffer. A NDOB 
bit set to one specifies that: 


a) the device server shall not transfer data from the Data-Out Buffer; 


b) if the Logical Block Provisioning VPD page (see 5.2.13) is not supported or the LBPRZ field (see 5.2.13) is set to O00b or xx1b, then the 
device server shall process the command as if the Data-Out Buffer contained user data set to all zeroes and protection information, if 
any, containing: 


A. the logical block guard field set to FFFFh; 
B). the logical block reference tag field set to FFFF_FFFFh; and 
C). the logical block application tag field set to FFFFh; 

and 


c) _ if the LBPRZ field is set to 010b, then the device server shall process the command as if the Data-Out Buffer contained user data set to 
the provisioning initialization pattern and protection information, if any, containing: 


A. the logical block guard field set to FFFFh; 
B). the logical block reference tag field set to FFFF_FFFFh; and 
C). the logical block application tag field set to FFFFh. 


See the WRITE SAME (10) command (see 3.73) for the definitions of the other fields in this command. 
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3.75 WRITE SAME (32) command 


The WRITE SAME (32) command (see table 239) requests that the device server transfer a single logical block from the data-out 
buffer and write the contents of that logical block. Each logical block includes user data and may include protection information, 
based on the WRPROTECT field and the medium format. 


Table 239 WRITE SAME (32) command 



















































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (7Fh) 

1 CONTROL 

2 
aisle Reserved 

5 

6 Reserved GROUP NUMBER 

7 ADDITIONAL CDB LENGTH (18h) 

8 (MSB) 

SERVICE ACTION (OO00Dh) 

9 (LSB) 
10 WRPROTECT ANCHOR UNMAP Obsolete Obsolete NDOB 
11 Reserved 

12 (MSB) 
see LOGICAL BLOCK ADDRESS 

19 (LSB) 
20 (MSB) 
seus EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 
23 (LSB) 
24 (MSB) 
25 EXPECTED LOGICAL BLOCK APPLICATION TAG se) 
26 (MSB) 
tp LOGICAL BLOCK APPLICATION TAG MASK ——————— 

27 (LSB) 
28 (MSB) 
eave NUMBER OF BLOCKS 
31 (LSB) 








See the WRITE SAME (10) command (see 3.73) for the definition of the function of this command. 


OPERATION CODE, ADDITIONAL CDB LENGTH, and SERVICE ACTION fields 


The OPERATION CODE field, the ADDITIONAL CDB LENGTH field, and the SERVICE ACTION field are defined in 2.2 and shall be set to the values 
shown in table 239 for the WRITE SAME (32) command. 


See the WRITE SAME (10) command (see 3.73) for the definitions of the GROUP NUMBER field, the WRPROTECT field, the ANCHOR bit, the 
UNMAP bit, the NDOB bit, the LOGICAL BLOCK ADDRESS field, and the NUMBER OF BLOCKS field. 
LOGICAL BLOCK REFERENCE TAG field 


When checking of the LOGICAL BLOCK REFERENCE TAG field is enabled (see 3.73), the EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG field 
contains the value of the LOGICAL BLOCK REFERENCE TAG field expected in the protection information of the first logical block accessed by the 
command instead of a value based on the LBA (see SBC-4). 


ATO bit, LOGICAL BLOCK APPLICATION TAG field and EXPECTED LOGICAL BLOCK APPLICATION TAG field 


If the ATO bit is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK APPLICATION TAG field is enabled (see 
table 217), then the LOGICAL BLOCK APPLICATION TAG MASK field contains a value that is a bit mask for enabling the checking of the LOGICAL 
BLOCK APPLICATION TAG field in every instance of protection information for each logical block accessed by the command. A LOGICAL BLOCK 
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APPLICATION TAG MASK bit set to one enables the checking of the corresponding bit of the EXPECTED LOGICAL BLOCK APPLICATION TAG field 
with the corresponding bit of the LOGICAL BLOCK APPLICATION TAG field in every instance of protection information. 


If the ATO bit is set to one in the Control mode page (see 5.3.12) and checking of the LOGICAL BLOCK APPLICATION TAG field is disabled (see 
table 217), or if the ATO bit is set to zero, then the LOGICAL BLOCK APPLICATION TAG MASK field and the EXPECTED LOGICAL BLOCK APPLICA- 
TION TAG field shall be ignored. 


3.76 WRITE STREAM (16) command 


The WRITE STREAM (16) command (see table 240) requests that the device server perform the actions defined for the WRITE (10) command 
(see 3.60). 


Table 240 WRITE STREAM (16) command 





Bit 7 6 5 4 3 2 1 0 

Byte 
0 OPERATION CODE (9Ah) 
1 WRPROTECT DPO FUA Reserved 
2 (MSB) 
































LOGICAL BLOCK ADDRESS 
9 (LSB) 

10 
11 
12 (MSB) 

13 TRANSFER LENGTH ——1sB) 
14 Reserved GROUP NUMBER 
15 CONTROL 








STR_ID 























OPERATION CODE field 
The OPERATION CODE field is defined in 2.2 and shall be set to the value shown in table 240 for the WRITE STREAM (16) command. 


STR_ID field 
The stream identifier (STR_ID) field specifies the stream identifier associated with this command as described in SBC-4. 


See the WRITE (10) command (see 3.60) for the definitions of the other fields in this command. 
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3.77 WRITE STREAM (32) command 


The WRITE STREAM (32) command (see table 240) requests that the device server perform the actions defined for the WRITE (32) command 
(see 3.63). 


Table 241 WRITE STREAM (32) command 







































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (7Fh) 
1 CONTROL 
2 

Reserved 
3 
4 (MSB) 

STR_ID 
5 (LSB) 
6 Reserved GROUP NUMBER 
7 ADDITIONAL CDB LENGTH (18h) 
8 (MSB) 
SERVICE ACTION (0010h) 
9 (LSB) 
10 WRPROTECT DPO FUA Reserved 
11 Reserved 
12 (MSB) 
LOGICAL BLOCK ADDRESS 
19 (LSB) 
20 (MSB) 
EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 
23 (LSB) 
24 (MSB) 
EXPECTED LOGICAL BLOCK APPLICATION TAG 
25 (LSB) 
26 (MSB) 
LOGICAL BLOCK APPLICATION TAG MASK oT 
27 (LSB) 
28 (MSB) 
TRANSFER LENGTH 

31 (LSB) 





OPERATION CODE, ADDITIONAL CDB LENGTH, and SERVICE ACTION fields 


The OPERATION CODE field, the ADDITIONAL CDB LENGTH field, and the SERVICE ACTION field are defined in 2.2 and shall be set to the values 
shown in table 241 for the WRITE STREAM (32) command. 


See the WRITE STREAM (16) command (see 3.76) for the definition of the STR_ID field. 
See the WRITE (32) command (see 3.63) for the definitions of the other fields in this command. 
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4.1 Commands for zoned block devices overview 


The commands for host managed zoned block devices are listed in Table 242. 


Table 242 Commands for host managed zoned block devices 





























Command Operation Code Reference 
CLOSE ZONE 94h/01h 4.2 
FINISH ZONE 94h/02h 4.3 
OPEN ZONE 94h/03h 44 
REPORT ZONES 95h/00h 45 
RESET WRITER POINTER 94h/04h 4.6 
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4.2 


CLOSE ZONE command (94h/01h) 


The CLOSE ZONE command (see table 243) requests the device server to perform close zone operations (see ZBC). 


Table 243. CLOSE ZONE command 






























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (94h) 

1 Reserved SERVICE ACTION (01h) 

2 (MSB) 
i ZONE ID 

9 (LSB) 
10 
ies Reserved 
13 
14 Reserved ALL 
15 CONTROL 











OPERATION CODE and SERVICE ACTION fields 


The OPERATION CODE field and the SERVICE ACTION field are defined in 2.2 and shall be set to the values shown in table 243 for the CLOSE 
ZONE command. 


ZONE ID field and ALL bit 


If the ALL bit is set to zero, then the ZONE ID field specifies the lowest LBA of the write pointer zone on which the device server shall perform a 
close zone operation. If the ALL bit is set to one, then the device server shall ignore the ZONE ID field. 


If the ALL bit is set to zero and the ZONE ID field: 


a) 


b) 


does not specify the lowest LBA of a write pointer zone (see ZBC), then the device server shall terminate the command with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB; or 


specifies the lowest LBA of a write pointer zone (see ZBC) and for the zone specified by the ZONE ID field, the Zone Condition is: 


A. READ ONLY, then the device server shall terminate the command with CHECK CONDITION status, with the sense key set 
to DATA PROTECT and additional sense code set to ZONE IS READ ONLY; 

B). OFFLINE, then the device server shall terminate the command with CHECK CONDITION status, with the sense key set to 
DATA PROTECT and additional sense code set to ZONE IS OFFLINE; 

C). EMPTY, CLOSED, or FULL, then the device server shall make no changes in the Zone Condition and not return an error; 
or 

D). IMPLICITLY OPENED or EXPLICITLY OPENED, then the device server shall perform a close zone operation (see ZBC) on 
the zone specified by the ZONE ID field. 


An ALL bit set to one specifies that the device server shall perform a close zone operation (see ZBC) on each zone with a Zone Condition of 
EXPLICIT OPEN or IMPLICIT OPEN. 


The CONTROL byte is defined in 2.2.7. 
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4.3 


FINISH ZONE command (94h/02h) 


The FINISH ZONE command (see table 244) requests the device server to perform finish zone operations (see ZBC). 


The device server returns the initialization pattern for all unwritten LBAs in this zone (see ZBC) in response to a read operation. 
The device server may write the initialization pattern to the media for unwritten LBAs. 


Table 244 FINISH ZONE command 



























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (94h) 

1 Reserved SERVICE ACTION (02h) 

2 (MSB) 
Ac ZONE ID 

9 (LSB) 
10 
ce Reserved 
13 
14 Reserved ALL 
15 CONTROL 











OPERATION CODE and SERVICE ACTION fields 


The OPERATION CODE field and the SERVICE ACTION field are defined in 2.2 and shall be set to the values shown in table 244 for the FINISH 
ZONE command. 


ZONE ID field and ALL bit 


If the ALL bit is set to zero, then the ZONE ID field specifies the lowest LBA of the write pointer zone on which the device server shall perform a 
finish zone operation. If the ALL bit is set to one, then the device server shall ignore the ZONE ID field. 


If the ALL bit is set to zero and the ZONE ID field: 


a) 


b) 


does not specify the lowest LBA of a write pointer zone (see ZBC), then the device server shall terminate the command with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB; or 


specifies the lowest LBA of a write pointer zone (see ZBC) and for the zone specified by the ZONE ID field, the Zone Condition is: 


A. READ ONLY, then the device server shall terminate the command with CHECK CONDITION status, with the sense key set 
to DATA PROTECT and additional sense code set to ZONE IS READ ONLY; 

B). OFFLINE, then the device server shall terminate the command with CHECK CONDITION status, with the sense key set to 
DATA PROTECT and additional sense code set to ZONE IS OFFLINE; 

C). FULL, then the device server shall make no changes in the Zone Condition and not return an error; or 

D). IMPLICITLY OPENED, EXPLICITLY OPENED, CLOSED, or EMPTY, then the device server shall perform a finish zone 


operation 
(see ZBC) on the zone specified by the ZONE ID field. 


An ALL bit set to one specifies that the device server shall perform a finish zone operation (see ZBC) on each zone with a Zone Condition of 
EXPLICIT OPEN, IMPLICIT OPEN, or CLOSED. 


The CONTROL byte is defined in 2.2.7. 
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4.4 OPEN ZONE command (94h/03h) 


The OPEN ZONE command (see table 245) requests the device server to perform open zone operations (see ZBC). 


Table 245 OPEN ZONE command 






























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (94h) 

1 Reserved SERVICE ACTION (03h) 

2 (MSB) 

ZONE ID 

9 (LSB) 
10 
ies Reserved 
13 
14 Reserved ALL 
15 CONTROL 











OPERATION CODE and SERVICE ACTION fields 


A. The OPERATION CODE field and the SERVICE ACTION field are defined in 2.2 and shall be set to the values shown in 
table 245 for the CLOSE ZONE command. 


ZONE ID field and ALL bit 


If the ALL bit is set to zero, then the ZONE ID field specifies the lowest LBA of the write pointer zone on which the device server shall perform a 
close zone operation. If the ALL bit is set to one, then the device server shall ignore the ZONE ID field. 
If the ALL bit is set to zero and the ZONE ID field: 


a) does not specify the lowest LBA of a write pointer zone (see ZBC), then the device server shall terminate the command with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB; or 
b) specifies the lowest LBA of a write pointer zone (see ZBC) and for the zone specified by the ZONE ID field, the Zone Condition is: 
A. READ ONLY, then the device server shall terminate the command with CHECK CONDITION status, with the sense key set 
to DATA PROTECT and additional sense code set to ZONE IS READ ONLY; 
B). OFFLINE, then the device server shall terminate the command with CHECK CONDITION status, with the sense key set to 
DATA PROTECT and additional sense code set to ZONE IS OFFLINE; 
C). EXPLICITLY OPENED or FULL, then the device server shall make no changes in the Zone Condition and not return an 
error; or 
D). IMPLICITLY OPENED, CLOSED, or EMPTY, then the device server shall perform an open zone operation (see ZBC) on the 
zone specified by the ZONE ID field. 


An ALL bit set to one specifies that the device server shall perform an open zone operation (see ZBC) on each zone with a Zone Condition of 
CLOSED. If the ALL bit is set to one, then the device server shall ignore the ZONE ID field. 


For a host managed zoned block device, if the ALL bit is set to one and the number of zones with a Zone Condition of EXPLICIT OPEN plus the 
number of zones with a Zone Condition of CLOSED is greater than the maximum number of open sequential write required zones, then the 
device server shall terminate the command with CHECK CONDITION status, with sense key set to DATA PROTECT and the additional sense code 
set to INSUFFICIENT ZONE RESOURCES. 


The CONTROL byte is defined in 2.2.7. 
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4.5 REPORT ZONES command (95h/00h) 


The REPORT ZONE command (see table 246) requests the device server to perform open zone operations (see ZBC). 


Table 246 REPORT ZONE command 





























Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (95h) 

1 Reserved SERVICE ACTION (00h) 

2 (MSB) 

7 ZONE START LBA 

9 (LSB) 
10 (MSB) 
ae ALLOCATION LENGTH 
13 (LSB) 
14 PARTIAL Reserved REPORTING OPTIONS 
15 CONTROL 














OPERATION CODE and SERVICE ACTION fields 

The OPERATION CODE field and the SERVICE ACTION field are defined in 2.2 and shall be set to the values shown in table 246 for the REPORT 
ZONE command. 

ZONE START LBA field 


The ZONE START LBA field specifies an LBA in the first zone to be reported. If the ZONE START LBA field does not specify the lowest LBA of a 
zone, then the device server uses the lowest LBA of the zone that contains the specified LBA to specify the first zone to be reported. If the ZONE 
START LBA field specifies an LBA that is greater than the value in the MAXIMUM LBA field (see table 250), then the device server shall terminate 
the command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to LOGICAL BLOCK 
ADDRESS OUT OF RANGE. 


ALLOCATION LENGTH field 
The ALLOCATION LENGTH field is defined in SPC-5. 


PARTIAL bit 
The PARTIAL bit modifies the definition of the ZONE LIST LENGTH field as described in 4.5.1 
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REPORTING OPTIONS field 


The REPORTING OPTIONS field (see table 247) specifies the information to be returned in the parameter data. 


Table 247. REPORT ZONES REPORTING OPTIONS field 
























































Code Description 

00h List all of the zones in the zoned block device. 

O1h List the zones with a Zone Condition of EMPTY. 

02h List the zones with a Zone Condition of IMPLICITLY OPENED. 

03h List the zones with a Zone Condition of EXPLICITLY OPENED. 

04h List the zones with a Zone Condition of CLOSED. 

05h List the zones with a Zone Condition of FULL. 

06h List the zones with a Zone Condition of READ ONLY. 

07h List the zones with a Zone Condition of OFFLINE. 

08h to OFh Reserved 

10h List of the zones with RWP Recommended set to true. 

11h List of the zones with Non-Sequential Write Resources Active set to true. 

12h to 3Eh Reserved 

3Fh List of the zones with a Zone Condition of NOT WRITE POINTER. 
CONTROL byte 


The CONTROL byte is defined in 2.2.7. 
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4.5.1 REPORT ZONES parameter data 
The REPORT ZONES parameter data is defined in table 248. 


Table 248 REPORT ZONES parameter data 































































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
a ZONE LIST LENGTH (n-63) 
3 (LSB) 
4 Reserved SAME 
5 
ae Reserved 
7 
8 (MSB) 
sae MAXIMUM LBA 
15 (LSB) 
16 
eae Reserved 
63 
ZONE DESCRIPTOR LIST 
64 
ate Zone descriptor [first] 
127 
n-63 
Zone descriptor [last] 
n 














ZONE LIST LENGTH field 
The ZONE LIST LENGTH field shall contain the length in bytes of the zone descriptors list. The zone descriptors list is the list of zones that: 
a) meet the requirements of the REPORTING OPTIONS field; and 
b) include the LBA specified by the ZONE START LBA field or have a lowest LBA that is greater than the LBA specified by the ZONE START 
LBA field. 
If the PARTIAL bit is set to zero, then the content of the ZONE LIST LENGTH field is not altered based on the allocation length (see SPC-5). If the 
PARTIAL bit is set to one then the ZONE LIST LENGTH field shall be set to the lesser of: 


a) the allocation length minus 64 if the allocation length is greater than 64; 
b) zero if the allocation length is less than or equal to 64; or 


c) the length of the zone descriptors list. 
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SAME field 


The SAME field is defined in table 249. If the ZONE LIST LENGTH field is zero then the SAME field is invalid and should be ignored by the appli- 
cation client. 


Table 249 SAME field description 





Code Description 





Oh The zone type and zone length in each zone descriptor may be different. 





th The zone type and zone length in each zone descriptor are equal to the zone type and zone length indicated in the first zone 
descriptor in the zone descriptor list. 





2h The zone type in each zone descriptor is equal to the zone type indicated in the first zone descriptor in the zone descriptor list. 
The zone length of each zone except the last zone is equal to the zone length of the first zone descriptor in the zone descriptor 
list. The zone length of the last zone descriptor is different than the zone length of the first descriptor in the zone descriptor list. 





3h The zone type in each descriptor may be different. The zone length in each zone descriptor is equal to the zone length indicated 
in the first zone descriptor in the zone descriptor list. 


4h to Fh| Reserved 

















MAXIMUM LBA field 
The MAXIMUM LBA field contains the LBA of the last logical block on the logical unit. 


Zone Descriptors 


The zone descriptors list contains zone descriptors that shall be sorted in ascending order based on the ZONE START LBA field of each zone 
descriptor. 


Each zone descriptor (see table 250) contains the description of a single zone. 


Table 250 Zone descriptor format 





Bit 7 6 5 4 3 2 1 0 
Byte 
0 Reserved ZONE TYPE 
ZONE CONDITION Reserved NON_SEQ RESET 




















Reserved 








ZONE LENGTH 





15 
16 








ZONE START LBA 





23 
24 





WRITE POINTER LBA 





31 
32 








Reserved 





63 
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ZONE TYPE field 
The ZONE TYPE field indicates the Zone Type (see ZBC) of zone as described in table 251. 


Table 251 Zone descriptor ZONE TYPE field 




















Code Description 

Oh Reserved 

th CONVENTIONAL 

2h SEQUENTIAL WRITE REQUIRED 
3h SEQUENTIAL WRITE PREFERRED 
4h to Fh Reserved 














The ZONE CONDITION field indicates the Zone Condition (see ZBC) of the zone as described in table 252. 


Table 252 Zone descriptor ZONE CONDITION field 















































Code Description The content of the WRITE POINTER LBA field is invalid 
Oh NOT WRITE POINTER yes 
th EMPTY no 
2h IMPLICITLY OPENED no 
3h EXPLICITLY OPENED no 
4h CLOSED no 
5htoCh | Reserved 

Dh READ ONLY yes 
Eh FULL yes 
Fh OFFLINE yes 

NON_SEQ bit 


The value of the non-sequential (NON_SEQ) bit is based on the Non-Sequential Write Resources Active zone attribute (see ZBC). 
If Non-Sequential Write Resources Active is: 


a) false, then the NON_ SEQ bit shall be set to zero; or 
b) true, then the NON_SEQ bit shall be set to one. 


RESET bit 
The value of the RESET bit is based on the RWP Recommended zone attribute (see ZBC). If RWP Recommended is: 
a) false, then the RESET bit shall be set to zero; or 


b) true, then the RESET bit shall be set to one. 


ZONE LENGTH field 
The ZONE LENGTH field indicates the number of logical blocks in this zone. 


ZONE START LBA field 
The ZONE START LBA field indicates the lowest LBA in this zone. 


WRITE POINTER LBA field 


The WRITE POINTER LBA field indicates the starting LBA that the application client should specify in the next write command associated with 
this zone (i.e., the write pointer). The content of the WRITE POINTER LBA field is invalid if the content of the ZONE CONDITION field (see table 
252) indicates that the WRITE POINTER LBA field is invalid. 
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4.6 RESET WRITE POINTER command (94h/04h) 


The RESET WRITE POINTER command (see table 253) requests the device server to perform reset write pointer operations 
(see ZBC). 


Table 253 RESET WRITE POINTER command 



























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 OPERATION CODE (94h) 

1 Reserved SERVICE ACTION (04h) 

2 (MSB) 
steis ZONE ID 

9 (LSB) 
10 
aide Reserved 
13 
14 Reserved ALL 
15 CONTROL 














OPERATION CODE and SERVICE ACTION fields 


The OPERATION CODE field and the SERVICE ACTION field are defined in 2.2 and shall be set to the values shown in table 253 for the RESET 
WRITE POINTER command. 


ZONE ID field and ALL bit 


If the ALL bit is set to zero, then the ZONE ID field specifies the lowest LBA of the write pointer zone on which the device server shall perform a 
reset write pointer operation. If the ALL bit is set to one, then the device server shall ignore the ZONE ID field. 


If the ALL bit is set to zero and the ZONE ID field: 


a) does not specify the lowest LBA of a write pointer zone (see ZBC), then the device server shall terminate the command with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB; or 


b) specifies the lowest LBA of a write pointer zone (see ZBC) and for the zone specified by the ZONE ID field, the Zone Condition is: 


A. READ ONLY, then the device server shall terminate the command with CHECK CONDITION status, with the sense key set 
to DATA PROTECT and additional sense code set to ZONE IS READ ONLY; 


B). OFFLINE, then the device server shall terminate the command with CHECK CONDITION status, with the sense key set to 
DATA PROTECT and additional sense code set to ZONE IS OFFLINE; 


C). EMPTY, then the device server shall make no changes in the Zone Condition and not return an error; or 


D). IMPLICITLY OPENED, EXPLICITLY OPENED, FULL, or CLOSED, then the device server shall perform a reset write pointer 
operation (see ZBC) on the zone specified by the ZONE ID field. 


An ALL bit set to one specifies that the device server shall perform a reset write pointer operation (see ZBC) on each zone with a Zone Condi- 
tion of IMPLICITLY OPENED, EXPLICITLY OPENED, FULL, or CLOSED. 


The CONTROL byte is defined in 2.2.7. 
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5. Parameters for direct access devices 
5.1 Diagnostic parameters 
5.1.1 Diagnostic page format and page codes for direct access devices 


This subclause describes the diagnostic page structure and the diagnostic pages that are applicable to all SCSI devices. 
Diagnostic pages specific to each device type are described in the command standard that applies to that device type. 


A SEND DIAGNOSTIC command with a PF bit set to one specifies that the SEND DIAGNOSTIC parameter list consists of a single 
diagnostic page and that the data returned by the subsequent RECEIVE DIAGNOSTIC RESULTS command that has the PCV bit set 
to zero shall use the diagnostic page format defined in table 254. A RECEIVE DIAGNOSTIC RESULTS command with a PCV bit set 
to one specifies that the device server return a diagnostic page using the format defined in table 254. 


Table 254 Diagnostic page format 









































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PAGE CODE 
1 PAGE CODE SPECIFIC 
2 (MSB) 
PAGE LENGTH (N-3) a =| 
3 (LSB) 
4 
DIAGNOSTIC PARAMETERS 
n 














Each diagnostic page defines a function or operation that the device server shall perform as a result of a SEND DIAGNOSTIC 
command or the information being returned as a result of a RECEIVE DIAGNOSTIC RESULTS command with the PCV bit equal to 
one. The diagnostic parameters contain data that is formatted according to the page code specified. 


PAGE CODE field 
The PAGE CODE field identifies the diagnostic page (see table 255). 


SCSI Commands Reference Manual, Rev. J 292 


www.seagate.com 


Parameters for direct access devices 
































Table 255 Diagnostic page codes 
Page Code Diagnostic Page Name Reference 
00h Supported Diagnostic Pages 5.1.2 
Defined by SES-3 for: 5.1.5 
a_ Enclosure services devices (i.e., SCSI devices with the PERIPHERAL DEVICE TYPE 
field set to ODh in standard INQUIRY data); and 
b SCSI devices with the ENCSERV bit set to one in standard INQUIRY data (see 
01h - 2Fh 3.6.2). 
NOTE These pages are described in SES-3 these 
pages are passed along to any attached 
enclosure services device. 
30h - 3Eh Reserved 
3Fh See specific SCSI transport protocol for definition SPC-5 
Translate Address Input diagnostic page 5.1.3 
40h 
Translate Address Output diagnostic page 5.1.4 
41h Obsolete 
Rebuild Assist Input diagnostic page 5.1.6 
42h 
Rebuild Assist Output diagnostic page 5.1.7 
43h - 7Fh See specific device type for definition 
80h - FFh Vendor specific 

















PAGE LENGTH field 
The PAGE LENGTH field contains the length in bytes of the diagnostic parameters that follow this field. If the application client sends a SEND 
DIAGNOSTIC command with a parameter list containing a PAGE LENGTH field that results in the truncation of any parameter, then the com- 
mand shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
INVALID FIELD IN PARAMETER LIST. 


The diagnostic parameters are defined for each diagnostic page code. The diagnostic parameters within a diagnostic page may be defined dif- 
ferently ina SEND DIAGNOSTIC command than in a RECEIVE DIAGNOSTIC RESULTS command. 
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5.1.2 Supported diagnostic pages (00h) 


The Supported Diagnostic Pages diagnostic page (see table 256) returns the list of diagnostic pages implemented by the device 
server. This diagnostic page shall be implemented if the device server implements the diagnostic page format option of the 
SEND DIAGNOSTIC and RECEIVE DIAGNOSTIC RESULTS commands. 


Table 256 Supported diagnostic pages 









































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PAGE CODE (00h) 
1 Reserved 
2 (MSB) 
PAGE LENGTH (N-3) 
3 (LSB) 
4 
SUPPORTED PAGE LIST 
n 














The definition of this diagnostic page for the SEND DIAGNOSTIC command includes only the first four bytes. If the PAGE LENGTH 
field is not zero, the device server shall terminate the SEND DIAGNOSTIC command with CHECK CONDITION status, with the 
sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. This diagnostic page 
instructs the device server to make available the list of all supported diagnostic pages to be returned by a subsequent RECEIVE 
DIAGNOSTIC RESULTS command. 


The definition of this diagnostic page for the RECEIVE DIAGNOSTIC RESULTS command includes the list of diagnostic pages 
supported by the device server. 


PAGE LENGTH field 
The PAGE LENGTH field specifies the length in bytes of the following supported page list. 


SUPPORTED PAGE LIST field 


The SUPPORTED PAGE LIST field shall contain a list of all diagnostic page codes, one per byte, implemented by the device server in ascending 
order beginning with page code 00h. 
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5.1.3 Translate Address input page (40h) 


Table 257 defines the Translate Address Input diagnostic page retrieved with the RECEIVE DIAGNOSTIC RESULTS command after 
the Translate Address Output diagnostic page (see 5.1.4) has been sent with the SEND DIAGNOSTIC command. If a Translate 
Address Output diagnostic page has not yet been processed, the results of a RECEIVE DIAGNOSTIC RESULTS command 
requesting this diagnostic page are vendor specific. 


Table 257 Translate Address page—input diagnostic page (40h) 









































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PAGE CODE (40h) 

1 Reserved 

2 (MSB) 

[> PAGE LENGTH (n-3) 

3 (LSB) 

4 Reserved SUPPLIED FORMAT 

5 RAREA ALTSEC ALTTK Reserved TRANSLATED FORMAT 

















TRANSLATED ADDRESS (if available) 





























6 (MSB) 
TRANSLATED ADDRESS 1 
13 (LSB) 
n-7 (MSB) 
TRANSLATED ADDRESS x (if required) 
n —(lsB) | 








PAGE CODE field 
The PAGE CODE field is defined in 5.1.1 and shall be set to the value defined in Table 257. 


PAGE LENGTH field 
The PAGE LENGTH field is defined in 5.1.1. 


SUPPLIED FORMAT field 
The SUPPLIED FORMAT field contains the value from the SEND DIAGNOSTIC command supplied format field (see table 260). 


RAREA (Reserved Area) bit 


1 A Reserved Area (RAREA) bit of one indicates that all or part of the translated address falls within a reserved area of the medium (e.g., 
speed tolerance gap, alternate logical block, vendor reserved area, etc.). If the entire translated address falls within a reserved area the 
target may not return a translated address. 


O — AnRAREA bit of zero indicates that no part of the translated address falls within a reserved area of the medium. 


TRANSLATED FORMAT field 
The TRANSLATED FORMAT field contains the format description of the translated address(es) (see table 44). 
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Table 258 Address Field for Short Logical Block Address Format 
































Bit Z 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
po LOGICAL BLOCK ADDRESS 
3 (LSB) 
4 0 0 0 0 0 0 0 0 
5 0 0 0 0 0 0 0 0 
6 0 0 0 0 0 0 0 0 
7 0 0 0 0 0 0 0 0 














Table 259 Address Field for Physical Sector Address Format 



































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
1 Jo CYLINDER NUMBER 
2 (LSB) 
3 HEAD NUMBER 
4 
SECTOR NUMBER 
7 














ALTSEC (Alternate Sector) bit 


1 An Alternate Sector (ALTSEC) bit of one indicates that the translated address is physically located in an alternate sector of the medium. If 
the drive cannot determine if all or part of the translated address is located in an alternate sector it shall set this bit to zero. 


QO = ANnALTSEC bit of zero indicates that no part of the translated address is located in an alternate sector of the medium or that the drive is 
unable to determine this information. 


ALTTRK (Alternate Track) bit 


1 An Alternate Track (ALTTRK) bit of one indicates that part or all of the translated address is located on an alternate track of the medium 
or the drive cannot determine if all or part of the translated address is located on an alternate track. 


0 An ALTTRK bit of zero indicates that no part of the translated address is located on an alternate track of the medium. 


TRANSLATED ADDRESS field 


The TRANSLATED ADDRESS field contains the address the target translated from the address supplied by the initiator in the SEND DIAGNOSTIC 
command. This field shall be in the format specified in the translate format field. The supported formats are shown in Tables 258 and 259. 
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5.1.4 Translate Address Output diagnostic page (40h) 


The Translate Address diagnostic pages allow the application client to translate an address in one of the formats supported by 
the FORMAT UNIT command (see 3.3.5.1) (i.e., a short block format address, a long block format address, a physical sector format 
address, or a bytes from index format address) into any one of the other formats. The address to be translated is sent to the 
device server with the SEND DIAGNOSTIC command and the results are returned to the application client by the RECEIVE 
DIAGNOSTIC RESULTS command. 


Table 260 defines the format of the Translate Address Output diagnostic page sent with the SEND DIAGNOSTIC command. The 
translated address is returned in the Translate Address Input diagnostic page (see 5.1.3). 


Table 260 Translate Address Output diagnostic page 





















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PAGE CODE (40h) 
1 Reserved 
2 (MSB) é - : 
3 PAGE LENGTH (000Ah) (LSB) 
4 Reserved SUPPLIED FORMAT 
5 Reserved TRANSLATE FORMAT 
6 (MSB) 
asses ADDRESS TO TRANSLATE 
13 (LSB) 











PAGE CODE field 
The PAGE CODE field is defined in 5.1.1 and shall be set to the value defined in table 260. 


PAGE LENGTH field 
The PAGE LENGTH field is defined in 5.1.1. 


SUPPLIED FORMAT field 


The SUPPLIED FORMAT field specifies the requested format of the ADDRESS TO TRANSLATE field. Valid values for this field are defined in table 
44. If the device server does not support the requested format it shall terminate the SEND DIAGNOSTIC command with CHECK CONDITION sta- 
tus with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


TRANSLATE FORMAT field 


The TRANSLATE FORMAT field specifies the format the device server shall use for the result of the address translation. Valid values for this field 
are defined in the DEFECT LIST FORMAT field of the FORMAT UNIT command. If the device server does not support the specified format it shall 
terminate the SEND DIAGNOSTIC command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional 
sense code set to INVALID FIELD IN PARAMETER LIST. 


ADDRESS TO TRANSLATE field 


The ADDRESS TO TRANSLATE field contains a single address descriptor which the application client is requesting the device server to translate. 
The format of this field depends on the value in the SUPPLIED FORMAT field. The formats are described in (see 3.3.5.1). If the short block format 
address descriptor is specified, the first four bytes of the ADDRESS TO TRANSLATE field shall contain the short block format address descriptor 
and the last four bytes shall contain 0000_0000h. 
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5.1.5 SCSI Enclosure Services pages (01h - 2Fh) 


When the drive supports the SCSI Enclosure Service (SES) pages, it does not process the contents of the pages. The drive 
attempts to transfer the page contents to the enclosure using the Enclosure Services Interface (ESI) as directed by the command. 
Errors detected in the transfer are returned to the initiator in response to the command. See SCSI-3 Enclosure Services-3 (SES-3) 
for descriptions of the data presented in the SES pages. Reference the drive product manual to determine if the SES pages are 
supported. 


Table 261 SCSI Enclosure Services page 



























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PAGE CODE (01h - 2Fh) 
1 Page Specific 
2 (MSB) 
PAGE LENGTH (n - 3) 

3 (LSB) 
4 

Page Specific 
n 

PAGE CODE 


The PAGE CODE (01h - 2Fh) defined in SCSI Enclosure Services - 3 (SES-3) standard. 


Page Specific 
The Page Specific field is defined in the SCSI-3 Enclosure Services - 3 (SES-3) standard. 


PAGE LENGTH 
The PAGE LENGTH field is defined in (see 5.1.1). 
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5.1.6 Rebuild Assist Input diagnostic page (42h) 


Application client sends a RECEIVE DIAGNOSTIC RESULTS command to retrieve a Rebuild Assist Input diagnostic page (see table 
262), which provides information about whether the rebuild assist mode (see SBC-4) is enabled or not and a device server's 
rebuild assist mode capabilities. 


Table 262 Rebuild Assist Input diagnostic page 
















































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PAGE CODE (42h) 
1 Reserved 
2 (MSB) 
PAGE LENGTH (4 + (2 xn)) 
3 (LSB) 
4 Reserved ENABLED 
5 
Reserved 
6 
7 PHYSICAL ELEMENT LENGTH (n) 
8 
DISABLED PHYSICAL ELEMENT MASK 
7+n 
8+n 
DISABLED PHYSICAL ELEMENT 
7+(2xn) 





PAGE CODE field 
The PAGE CODE field is defined in 5.1.1 and shall be set to the value defined in table 262. 


PAGE LENGTH field 
The PAGE LENGTH field is defined in 5.1.1. 


ENABLED bit 
1 An ENABLED bit set to one indicates that the rebuild assist mode is enabled. 
0 An ENABLED bit set to zero indicates that the rebuild assist mode is disabled. 


PHYSICAL ELEMENT LENGTH field 


The PHYSICAL ELEMENT LENGTH field indicates the length in bytes of the DISABLED PHYSICAL ELEMENT MASK field and the length in bytes of 
the DISABLED PHYSICAL ELEMENT field. 


DISABLED PHYSICAL ELEMENT MASK field 


The bits in the DISABLED PHYSICAL ELEMENT MASK field indicate the bits in the DISABLED PHYSICAL ELEMENT field that are supported. Each 
bit set to one in the DISABLED PHYSICAL ELEMENT MASK field indicates that the corresponding bit in the DISABLED PHYSICAL ELEMENT field is 
supported and may be set to one in a Rebuild Assist Output diagnostic page sent with a SEND DIAGNOSTIC command. 


DISABLED PHYSICAL ELEMENT field 


The bits in the DISABLED PHYSICAL ELEMENT field indicate the physical elements that are disabled in this logical unit. Each bit set to one indi- 
cates that a physical element is disabled, and the device server shall report predicted read errors and predicted write errors for the associated 
group of LBAs. 
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5.1.7 Rebuild Assist Output diagnostic page (42h) 
An application client sends a SEND DIAGNOSTIC command to send a Rebuild Assist Output diagnostic page (see table 263) that: 


a) enables or disables rebuild assist mode (see SBC-4); and/or 


b) puts the logical unit in a simulated failure mode by disabling physical elements in conjunction with rebuild assist mode 
(see SBC-4). 


Table 263 Rebuild Assist Output diagnostic page 




































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PAGE CODE (42h) 
1 Reserved 
2 (MSB) 
PAGE LENGTH (4 + (2 xn)) 
3 (LSB) 
4 Reserved ENABLED 
5 
Reserved 
6 
7 PHYSICAL ELEMENT LENGTH (n) 
8 
DISABLED PHYSICAL ELEMENT MASK 
7+n 
8+n 
DISABLE PHYSICAL ELEMENT 
7+(2xn) 


PAGE CODE field 
The PAGE CODE field is defined in 5.1.1 and shall be set to the value defined in table 263. 


PAGE LENGTH field 
The PAGE LENGTH field is defined in (see 5.1.1). 
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ENABLED bit 
1 The ENABLED bit set to one indicates that, after all fields in this diagnostic page have been validated: 
a) aself-test of the physical elements in the logical unit may be performed; and 
b) rebuild assist mode is enabled. 
O The ENABLE bit set to zero specifies that: 
a) rebuild assist mode shall be disabled; 
) the other fields in this page shall be ignored; and 
) all physical elements shall be enabled (i-e., shall not simulate a predicted error response). 


a Ft 


PHYSICAL ELEMENT LENGTH field 


The PHYSICAL ELEMENT LENGTH field shall be set to the same value that is returned in the PHYSICAL ELEMENT LENGTH field in the Rebuild 
Assist Input diagnostic page. 


If the PHYSICAL ELEMENT LENGTH field is not set to the same value that is returned in the PHYSICAL ELEMENT LENGTH field in the Rebuild 
Assist Input diagnostic page, then the device server shall terminate the command with CHECK CONDITION status with the sense key set to 
ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


DISABLED PHYSICAL ELEMENT MASK field 
The device server shall ignore the DISABLED PHYSICAL ELEMENT MASK field. 


DISABLED PHYSICAL ELEMENT field 


Each bit in the DISABLE PHYSICAL ELEMENT field specifies a physical element that shall be disabled. A bit set to one in the DISABLE PHYSICAL 
ELEMENT field specifies that the device server shall respond to read commands and write commands specifying LBAs associated with that 
physical element as if the associated LBAs have predicted errors. A bit set to zero in the DISABLE PHYSICAL ELEMENT field specifies that the 
device servers shall not respond to read commands and write commands specifying LBAs associated with that physical element as if the asso- 
ciated LBAs do not have predicted errors. If the ENABLE bit is set to one, and the DISABLE PHYSICAL ELEMENT field specifies: 


a) any bits set to one that are not supported by the logical unit; 
b) all bits that are supported by the logical unit are set to one; or 
c) setting to zero any bits that are set to one, 


then the device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST 
and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 
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5.2 Log parameters 


5.2.1 Summary of log page codes 
The page code assignments for the log pages are listed in table 264. 


Table 264 Log page codes 


Parameters for direct access devices 







































































Page Code Subpage Code Log Page Name Reference 
OFh 00h Application Client 5.2.3 
15h 00h Background Scan 5.2.4 
15h 02h Background Operation 5.2.5 
37h 00h Cache Statistics 5.2.6 
ODh 02h Environmental Limits 5.2.7 
ODh Oth Environmental Reporting 5.2.8 
03h 00h Read Error Counter 5.2.9 
05h 00h Verify Error Counter 5.2.9 
02h 00h Write Error Counter 5.2.9 
3Eh 00h Factory Log 5.2.10 
08h 00h Format Status 5.2.11 
2Fh 00h Informational Exceptions 5.2.12 
0Ch 00h Logical Block Provisioning 5.2.13 
06h 00h Non-Medium Error 5.2.14 
15h O1h Pending Defects 5.2.15 
1Ah 00h Power Condition Transitions 5.2.16 
18h 00h Protocol Specific Port 5.2.17 
10h 00h Self-Test Results 5.2.18 
11h 00h Solid State Media 5.2.19 
OEh 00h Start-Stop Cycle Counter 5.2.20 
00h 00h Supported Log Pages 5.2.21 
00h FFh Supported Log Pages and Subpages 5.2.22 
ODh 00h Temperature 5.2.23 
OEh Oth Utilization 5.2.24 
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5.2.2 Log page structure 


This subclause describes the log page structure and the log pages that are applicable to all SCSI devices. Log pages specific to 
each device type are described in the command standard that applies to that device type. The LOG SELECT command (see 3.7) 
supports the ability to send zero or more log pages. The LOG SENSE command (see 3.8) returns a single log page specified in the 


PAGE CODE field of the CDB. 
5.2.2.1 Log page format 


Each log page begins with a four-byte page header followed by zero or more variable-length log parameters defined for that log 
page. The log page format is defined in table 265. 


Table 265 Log page format 







































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF PAGE CODE 
1 SUBPAGE CODE 
2 (MSB) 
PAGE LENGTH (n-3) as 
3 (LSB) 
Log parameter(s) 
4 
Log parameter (First) 
(Length x) 
x+3 
n-y+1 
Log parameter (Last) 
(Length y) 
n 
DS (DISABLE SAVE) bit 


0 For the LOG SENSE command (see 3.8), if the DS bit is set to zero, the log parameters are saved when the SP bit is set to one. 


1 For the LOG SENSE command, if the DS bit is set to one, the log parameters are not saved. For the LOG SELECT command (see 3.7), the 


disable save (DS) bit operates in conjunction with the parameter code reset (PCR) bit, the save parameters (SP) bit, the page control (PC) 
field, and the PARAMETER LIST LENGTH field in the CDB. 


SPF (SUBPAGE FORMAT) bit 
0 If the SPF bit is set to zero, the SUBPAGE CODE field shall contain OOh. 


1 If the SPF bit is set to one, the SUBPAGE CODE field shall contain a value between O1h and FFh. 


PAGE CODE field 
The value in the PAGE CODE field is the number of the log page being transferred. 
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SUBPAGE CODE field 
The value in the SUBPAGE CODE field is the number of the subpage page being transferred. 
If an application client specifies values in the PAGE CODE field and SUBPAGE CODE field for a log page that is reserved or not 


implemented by the logical unit, then the device server shall terminate the LOG SELECT command with CHECK CONDITION 
status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


If the PARAMETER LIST LENGTH field in a LOG SELECT CDB contains zero, the meanings for the PCR bit, SP bit, and PC field are 
defined in table 68. 


If the PARAMETER LIST LENGTH field in a LOG SELECT CDB contains a non-zero value (i.e., when parameter data is being sent with the LOG 
SELECT command), table 266 defines the meaning for the combinations of values for: 
a) the PCR bit, the SP bit, and the PC field in the LOG SELECT CDB; and 


b) the DS bit in the LOG SELECT parameter data. 


Table 266 LOG SELECT PCR bit, SP bit, and DS bit meanings when parameter list length is not zero 





PCR SP DS 
bit bit bit Description 





Ob Ob xb The device server shall set the specified values to the values in the parameter list and shall not save any values to 
non-volatile media. 





Ob 1b Ob The device server shall set the specified values to the values in the parameter list and shall process the optional 
saving of log parameter values as follows: 

a) If default data counter values are specified (see table 74), no values shall be saved; 

b) If values other than default data counter values are specified and the device server implements saving of 
the specified values, then the device server shall save the specified values in the parameter list to 
non-volatile media; or 

c) Ifvalues other than default values are specified and the device server does not implements saving of one or 
more of the specified values, then the device server shall terminate the command with CHECK CONDITION 
status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN 








PARAMETER LIST. 
Ob 1b 1b The device server shall set the specified values to the values in the parameter list and shall not save any values in 
the specified log page to non-volatile media. 
1b xb xb The device server terminate the command with CHECK CONDITION status, with the sense key set to ILLEGAL 


REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 


The specified parameters are determined by the format and linking field contents (see table 268) in the LOG SELECT parameter data and by the PC field 
contents (see table 74) in the LOG SELECT CDB. 




















PAGE LENGTH field 


The value in the PAGE LENGTH field is the length in bytes of the following log parameters. If the application client sends a LOG SELECT com- 
mand with a log page length that results in the truncation of any parameter, the device server shall terminate the command with CHECK CON- 
DITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 
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5.2.2.2 Log parameter format 


5.2.2.2.1 Introduction 


Most log pages contain one or more special data structures called log parameters (see table 267). Log parameters may be data 
counters of a particular event(s), the conditions under which certain operations were performed, or list parameters that contain 
a character string description of a particular event. 


Table 267 ~Log parameter 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

7 PARAMETER CODE (sB) 

2 PARAMETER CONTROL BYTE - (see 5.2.2.2.2) 

3 PARAMETER LENGTH (N-3) 

4 

PARAMETER VALUE 
n 





Each log parameter begins with a four-byte parameter header followed by one or more bytes of PARAMETER VALUE data. 


PARAMETER CODE field 


The PARAMETER CODE field identifies the log parameter being transferred for that log page. The device server shall return the log parameters 
in a log page in ascending order based on the value in their PARAMETER CODE field. 


If an application client specifies a value in the PARAMETER CODE field in the LOG SELECT command parameter data that is reserved or not 
implemented by the logical unit, then the device server shall terminate the command with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


PARAMETER LENGTH field 


The PARAMETER LENGH field specifies the length in bytes of the PARAMETER VALUE field that follows. If the application client specifies a 
parameter length that results in the truncation of the PARAMETER VALUE field, the command shall be terminated with CHECK CONDITION sta- 
tus, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


If an application client sends a log parameter that is not supported by the logical unit, the command shall be terminated with CHECK CONDI- 
TION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


PARAMETER VALUE field 


If the application client sends a log parameter value of the PARAMETER VALUE field that is outside the range supported by the logical unit, and 
rounding is implemented for that parameter, the device server may either: 


a) round to an acceptable value and terminate the command as described in 2.3; or 
b) terminate the command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set 
to INVALID FIELD IN PARAMETER LIST. 


If the parameter data for one LOG SELECT command contains more than one log page and the log pages are not in ascending order by page 
code value then subpage code value, then the device server shall terminate the command with CHECK CONDITION status, with the sense key 
set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


If the parameter data for one LOG SELECT command contains more than one log parameter in any one log page and the log parameters are not 
in ascending order by parameter code value, then the device server shall terminate the command with CHECK CONDITION status, with the 
sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


Application clients should send LOG SENSE commands prior to sending LOG SELECT commands to determine supported log pages and page 
lengths. 


The SCSI target device may provide independent sets of log parameters for each logical unit or for each combination of logical units and |_T 
nexuses. If the SCSI target device does not support independent sets of log parameters and any log parameters are changed that affect other 
|_T nexuses, then the device server shall establish a unit attention condition (see SAM-5) for the initiator port associated with every I_T nexus 
except the I_T nexus on which the LOG SELECT command was received, with the additional sense code set to LOG PARAMETERS CHANGED. 
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5.2.2.2.2. Parameter control byte 


5.2.2.2.2.1 Introduction 


The DU bit, TSD bit, and FORMAT AND LINKING field are collectively referred to as the parameter control byte. These fields are 
described in this subclause. 


DU (Disable Update) bit 


For cumulative log parameter values, indicated by the PC field (see table 74) of the LOG SELECT command and LOG SENSE command, the dis- 
able update (DU) bit is defined as follows: 


0 DU set to zero indicates that the device server shall update the log parameter value to reflect all events that should be noted by that 
parameter; or 


1 DU set to one indicates that the device server shall not update the log parameter value except in response to a LOG SELECT command 
that specifies a new value for the parameter. 


Note. | When updating cumulative log parameter values, a device server may use volatile memory to hold these values until a LOG SELECT or 
LOG SENSE command is received with an SP bit set to one or a vendor specific event occurs. As a result the updated cumulative log 
parameter values may be lost if a power cycle occurs. 


If the PC field (see table 74) indicates that threshold values or default values are being processed, the device server shall: 

a) set the DU bit to zero, if a LOG SENSE command is being processed; and 

b) ignore the DU bit, if a LOG SELECT command is being processed. 
Regardless of the value in the PC field, the device server shall process ASCII format list log parameters (see 5.2.2.2.2.4) and binary 
format list log parameters (see 5.2.2.2.2.5) by: 

a) setting the DU bit to zero, if a LOG SENSE command is being processed; and 

b) ignoring the DU bit, ifa LOG SELECT command is being processed. 


TSD (Target Save Disable) bit 


0 A target save disable (TSD) bit set to zero indicates that the logical unit implicitly saves the log parameter at vendor specific intervals. 
This implicit saving operation shall be done frequently enough to insure that the cumulative parameter values retain statistical signifi- 
cance 
(i.e., across power cycles). 


1 ATSD bit set to one indicates that either the logical unit does not implicitly save the log parameter or implicit saving of the log parame- 
ter has been disabled individually by an application client setting the TSD bit to one. An application client may disable the implicit sav- 
ing for all log parameters without changing any TSD bits using the GLTSD bit in the Control mode page. (see 5.3.12). 


FORMAT AND LINKING field 
The FORMAT AND LINKING field (see table 268) indicates the type of log parameter. 


Table 268 FORMAT AND LINKING field 

















Code Log parameter type Reference 
00b Bounded data counter 5.2.2.2.2.2 
01b ASCII format list 5.2.2.2.2.4 
10b Bounded data counter or unbounded data counter 5.2.2.2.2.2 or 5.2.2.2.2.3 
11b Binary format list 5.2.2.2.2.5 
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5.2.2.2.2.2 


Parameters for direct access devices 


Parameter control byte values for bounded data counter parameters 


The device server shall return LOG SENSE parameter control byte values and process LOG SELECT parameter control byte values as shown in table 
269 for any log parameter that is defined to be a bounded data counter log parameter. 














Table 269 Parameter control byte values for bounded data counter parameters 
; : Value for Value for sien 
Field or bit LOG SENSE | LOG SELECT Description 

DU Oor1 Oor1 When the DU bit is set to zero, the device server shall update the log parameter value to 
reflect all events that should be noted by that parameter. When the DU bit is set to one, the 
device server shall not update the log parameter value except in response to a LOG SELECT 
command that specifies a new value for the parameter. 

TSD Oor1 Oor1 When the TSD bit is set to zero, the device server shall save the log parameter to its 
medium at vendor specific intervals. When the TSD bit is set to one, implicit saving of the 
log parameter is disabled by an application client. 

FORMAT 00b or 10b 00b or 10b The log parameter is a data counter (see table 268) and the handling of a parameter that 

AND reaches its maximum value is described in this subclause. 

LINKING 




















If a LOG SELECT command contains a bounded data counter log parameter in which the parameter control byte values differ 
from those shown in table 269, then the command shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


Each bounded data counter log parameter contains one saturating counter that is: 


a) associated with one or more events; and 
b) incremented whenever one of these events occurs. 


If the counter in a bounded data counter log parameter has associated with it a vendor specific maximum value, then upon 
reaching this maximum value, the data counter shall not be incremented (i.e., its value does not wrap). 


If the counter in a bounded data counter log parameter reaches its maximum value (i.e., saturates), the device server shall: 


a) set the DU bit to one; 
b) handle other bounded data counter log parameters in the log page based on the contents of the FORMAT AND LINKING field in each 
other log parameter as follows: 
A._ if the FORMAT AND LINKING field is set to 00b, then that other log parameter shall stop incrementing until reinitialized 
by a LOG SELECT command; or 
B). if the FORMAT AND LINKING field is set to 10b, then that other log parameter shall not stop incrementing, but may be 
reinitialized by a LOG SELECT command. 
and 
c) notalter the handling of other log parameters in the log page that are: 
A. unbounded data counter log parameters (see 5.2.2.2.2.3); 
B). ASCII format list log parameters (see 5.2.2.2.2.4); and 
C). binary format list log parameters (see 5.2.2.2.2.5). 


The processing of a command shall not be altered because the counter in a bounded data counter log parameter reaches its 
maximum value (i.e., saturates). If the RLEC bit is set to one in the Control mode page (see 5.3.12) and the processing of a 
command encounters no exception conditions other than the counter in a bounded data counter log parameter reaching its 
maximum value, then the command shall be terminated with CHECK CONDITION status, with the sense key set to RECOVERED 
ERROR, and the additional sense code set to LOG COUNTER AT MAXIMUM. 
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5.2.2.2.2.3 


The device server shall return LOG SENSE parameter control byte values and process LOG SELECT parameter control byte values 


Parameters for direct access devices 


Parameter control byte values for unbounded data counter parameters 


as shown in table 270 for any log parameter that is defined to be an unbounded data counter log parameter. 











Table 270 Parameter control byte values for unbounded data counter parameters 
Field Value for Value for Description 
or bit LOG SENSE LOG SELECT P 
DU Oorl Oorl If the DU bit is set to zero, the device server shall update the log parameter value or values 
to reflect all events that should be noted by that parameter. If the DU bit is set to one, the 
device server shall not update the log parameter value or values except in response to a 
LOG SELECT command that specifies a new value for the parameter. 

TSD Oor1 Oor1 If the TSD bit is set to zero, the device server shall save the log parameter to its medium at 
vendor specific intervals. If the TSD bit is set to one, implicit saving of the log parameter is 
disabled by an application client. 

FORMAT 10b 10b The log parameter is a data counter for which saturation of another log parameter does 

AND not affect the incrementing of this log parameter (see table 268). 

LINKING 

















Ifa LOG SELECT command contains an unbounded data counter log parameter in which the parameter control byte values differ 
from those shown in table 270, then the command shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


Each unbounded data counter log parameter contains one or more saturating counters or wrapping counters. The description of 
each counter field in the log parameter defines when the device server modifies the contents of the counter that is transferred in 
that field. 


Changes in an unbounded data counter (e.g., a counter reaching saturation or another maximum value) shall not affect the 
handling of other log parameters in the log page. The processing of a command and the status returned by that command shall 
not be altered because a counter in an unbounded data counter log parameter saturates or reaches its maximum value. 


The device server shall not change the value in the DU bit in an unbounded data counter log parameter unless requested to do 
so by a LOG SELECT command. 


5.2.2.2.2.4 Parameter control byte values for ASCII format list log parameters 


The device server shall return LOG SENSE parameter control byte values and process LOG SELECT parameter control byte values 
as shown in table 271 for any log parameter that is defined to be an ASCII format (see SPC-5) list log parameter. 














Table 271 Parameter control byte values for ASCII format list log parameters 
Field Value for Value for Desciption 
or bit LOG SENSE LOG SELECT P 

DU 0 ignored The DU bit is not defined for list parameters. 

TSD Oor1 Oor1 If the TSD bit is set to zero, the device server shall save the log parameter to its medium at 
vendor specific intervals. If the TSD bit is set to one, implicit saving of the log parameter is 
disabled by an application client. 

FORMAT 01b 01b The log parameter is an ASCII format list parameter (see table 268). 

AND 

LINKING 




















If a LOG SELECT command contains an ASCII format list log parameter in which the parameter control byte values differ from 
those shown in table 271, then the command shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 
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5.2.2.2.2.5 Parameter control byte values for binary format list log parameters 


The device server shall return LOG SENSE parameter control byte values and process LOG SELECT parameter control byte values 
as shown in table 272 for any log parameter that is defined to be a binary format list log parameter. 


Table 272 Parameter control byte values for binary format list log parameters 


Field Value for Value for 


or bit LOG SENSE | LOG SELECT Description 





DU 0 ignored The DU bit is not defined for list parameters. 





TSD Oorl Oorl If the TSD bit is set to zero, the device server shall save the log parameter to its medium at 
vendor specific intervals. If the TSD bit is set to one, implicit saving of the log parameter is 
disabled by an application client. 





FORMAT 01b 01b The log parameter is a binary format list parameter (see table 268). 
AND 
LINKING 




















If a LOG SELECT command contains a binary format list log parameter in which the parameter control byte values differ from 
those shown in table 272, then the command shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 


5.2.2.3 Resetting and setting log parameters 
In a LOG SELECT command, an application client may specify that: 


a) all the parameters in a log page or pages are to be reset (i.e., the PCR bit set to one); 
or 


b) individual parameters in log page are to be changed to specified new values 
(i.e., the PCR bit set to zero and the PARAMETER LIST LENGTH field not set to zero). 


The device server handling of these requests depends on the log parameter that is being reset or changed, and is defined in the 
table that defines the log parameter using the keywords defined in table 273. 


Table 273 Keywords for resetting or changing log parameters 


Device server handling when 











Reyword PCR bit is set to one /@! PCR bit is set to zero [b] 
Always |Reset the log parameter Change the log parameter 
Reset Only |Reset the log parameter If any changes are requested in the parameter value field of the log parameter, then 





a) terminate the command with CHECK CONDITION status, with the sense key set to ILLEGAL 
Never Do not reset the log parameter. REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST; and 


b) do not make any requested changes in any field in any log parameter in any log page 


[a] If the PCR bit is set to one and the PARAMETER LIST LENGTH field is not set to zero. then the LOG SELECT command shall be termi- 
nated (see table 266). 


[b] If the PCR bit is set to zero and the PARAMETER LIST LENGTH field is set to zero. then no log parameters are changed (see 3.7.1). 
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5.2.3 


Application Client log page (OFh/00h) 
The parameter codes for the Application Client log page are listed in Table 274. 
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Table 274 Application Client log page parameter codes 
Resettable or 
Parameter code Description [al Pasa 
Changeable (PCR) requirements 
0000h to 003Fh Mandatory 
= General Usage Application Client Always | 
0040h to OFFFh Optional 
all others Reserved 
[a] The keywords in this column -- Always, Reset Only, and Never -- are defined in 5.2.2.3. 











The Application Client log page (see table 275) provides a place for application clients to store information. The page code for 
the application client page is OFh. 


















































Table 275 Application client log page 

Bit 7 6 5 4 3 1 0 
Byte 

0 DS SPF (0b) PAGE CODE (0Fh) 

1 SUBPAGE CODE (00h) 

2 (MSB) 

PAGE LENGTH (n-3) 
3 (LSB) 
Application client log parameters 
4 
First application client log parameter 
= Last application client log parameter 














DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field 


The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field are described in 5.2.2. 


Parameter codes 0000h through OFFFh are for general usage application client data. The intended use for this information is to 
aid in describing the system configuration and system problems, but the specific definition of the data is application client 
specific. The general usage application client data parameters all have the format shown in table 276. 
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Table 276 General usage application client parameter data 



























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE 

1 (LSB) 

2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 

3 PARAMETER LENGTH (FCh) 

4 

GENERAL USAGE PARAMETER BYTES 

255 
PARAMETER CODE field 


For general usage application client data, the value in the PARAMETER CODE field shall be between 0000h and OFFFh. The first supported gen- 
eral usage application client parameter code shall be 0000h and additional supported parameters shall be sequentially numbered. If any gen- 
eral usage parameter codes are implemented, the device shall support at least 64 general usage parameter descriptors and they shall be 
parameter codes 0000h through 003Fh. 


PARAMETER LENGTH value 
For the general usage application client parameter, the PARAMETER LENGTH value for each parameter shall be FCh. 


GENERAL USAGE PARAMETER BYTES 


The values stored in the GENERAL USAGE PARAMETER BYTES represent data sent to the device server in a previous LOG SELECT command. If a 
previous LOG SELECT command has not occurred, the data is vendor specific. 
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5.2.4 Background Scan log page (15h/00h) 


The Background Scan log page (see table 278) returns the background scanning status parameter and zero or more Medium 
Scan parameters when background scanning is supported. The Background Scan Status parameter provides information about 
background pre-scan and background medium scan operations. Each Background Scan log entry corresponds to a logical block 
where an error was detected. If the Background Scan log page is filled up, a new Background Scan parameter overwrites the 
oldest entry. When a LOG SELECT command with PCR bit set to one is processed all Background Scan parameters are deleted, 
however, the values in the Background Scan Status parameter shall not be affected. 


Table 277 defines the parameter codes for the Background Scan log page. 


Table 277 Background Scan log page parameter codes 






































Parameter code Description Resettable or Reference Support 
Changeable !#! Required 

0000h Background Scan Status parameter Never Mandatory 

0001h - 0800h Background Scan parameter Reset Optional !] 
Only 

8000h - AFFFh Vendor specific n/a Optional 

All others Reserved 

[a] The keywords in this column -- Always, Reset Only, and Never -- are defined in 5.2.2.3. 

[b] If the Background Scan log page is supported, then at least one Background Scan log parameter shall be supported. 





The Background Scan log page has the format shown in table 278. 


Table 278 Background Scan log page 







































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS (1) SPF (0) PAGE CODE (15h) 
1 SUBPAGE CODE(00h) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 
Background Scan Status log parameter 
4 
ow Background Scan Status Parameter (see table 279) 
19 
Background Scan parameter list 
20 (MSB) 
Background Scan parameter (first) (see table 281) 
43 (LSB) 
n-23 (MSB) 
Background Scan parameter (last) (see table 281) 
n (LSB) 
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The background Scan Status parameter (see table 279) contains status information about the background pre-scan and 


background medium scan features. 



















































































Table 279 Background Scan Status parameter format 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PARAMETER CODE (0000h) 
1 (LSB) 
2 Parameter control byte - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (0Ch) 
4 (MSB) 
ACCUMULATED POWER ON MINUTES 
7 (LSB) 
8 Reserved 
9 BACKGROUND SCAN STATUS 
10 (MSB) 
NUMBER OF BACKGROUND SCANS PERFORMED 
11 (LSB) 
12 (MSB) 
BACKGROUND MEDIUM SCAN PROGRESS 
13 (LSB) 
14 
NUMBER OF BACKGROUND MEDIUM SCANS PERFORMED 
15 
PARAMETER CODE field 


For general usage application client data, the value in the PARAMETER CODE field shall be between 0000h and OFFFh. The first supported gen- 
eral usage application client parameter code shall be 0000h and additional supported parameters shall be sequentially numbered. If any gen- 
eral usage parameter codes are implemented, the device shall support at least 64 general usage parameter descriptors and they shall be 


parameter codes 0000h through 003Fh. 


PARAMETER LENGTH field 


The PARAMETER LENGTH field indicates that number of bytes remaining in the log parameter. 


ACCUMULATED POWER ON MINUTES field 


The ACCUMULATED POWER ON MINUTES field indicates the number of minutes the device server has been powered on since 
manufacturing. 
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Table 280 defines the BACKGROUND SCAN STATUS field. 


Table 280 Background Scan Status field 









































Code Description 

00h No background scans active 

Oth Background medium scan is active 

02h Background pre-scan is active 

03h Background medium scan halted due to fatal error 

04h Background medium scan halted due to a vendor-specific pattern of errors 

05h Background medium scan halted due to medium formatted without P-list 

06h Background medium scan halted - vendor-specific cause 

07h Background medium scan halted due to temperature out of allowed range 

08h Background medium scan halted, waiting for Background Medium Interval timer expiration. 
09h - FFh Reserved 








NUMBER OF SCANS PERFORMED field 


The NUMBER OF SCANS PERFORMED field indicates the number of background scans (i.e., the total number of background pre-scan operations 
plus the number of background medium scan operations) that have been performed since the SCSI target device was shipped by the manufac- 
turer. 


BACKGROUND MEDIUM SCAN PROGRESS field 


The BACKGROUND MEDIUM SCAN PROGRESS field indicates the percent complete of a background scan operation in progress. The returned 
value is anumerator that has 65 536 (i.e., 1_0000h) as its denominator. If there is no background scan operation in progress (i.e., no background 
scan operation has been initiated since power on or the most recent background scan operation has completed), then the device server shall 
set the BACKGROUND MEDIUM SCAN PROGRESS field to 0000h. 


NUMBER OF BACKGROUND MEDIUM SCAN PERFORMED field 


The NUMBER OF BACKGROUND MEDIUM SCAN PERFORMED field indicates the number of background medium scan operations that have 
been performed since the SCSI target device was shipped by the manufacturer. If the NUMBER OF BACKGROUND MEDIUM SCAN PERFORMED 
field contains 0000h, then the number of background medium scan operations is not reported. 
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A Background Scan parameter (see table 281) describes a defect location on the medium that was encountered by background 
scanning. 


Table 281 Background Scan parameter format 







































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PARAMETER CODE (0001h - 0800h) 

1 (LSB) 

2 Parameter control byte — binary format list log parameter (see 5.2.2.2.2.5) 

3 PARAMETER LENGTH (14h) 

4 (MSB) 
Bare ACCUMULATED POWER ON MINUTES 

7 (LSB) 
8 REASSIGN STATUS SENSE KEY 

9 ADDITIONAL SENSE CODE 

10 ADDITIONAL SENSE CODE QUALIFIER 

11 

Vendor-specific 

15 

16 (MSB) 

Saxe LOGICAL BLOCK ADDRESS 

23 (LSB) 














PARAMETER LENGTH field 
The PARAMETER LENGTH field indicates the number of bytes remaining in the log parameter. 


ACCUMULATED POWER ON MINUTES field 


The ACCUMULATED POWER ON MINUTES field indicates the number of minutes the device server has been powered on since manufacturing at 
the time the background scan error occurred. 
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Table 282 defines the REASSIGN STATUS field. 









































Table 282 REASSIGN STATUS field 
LOWIR bit '#! | Reason 
Code Original 
0 1 E 2 [bl Additional conditions 
rror 
th ee _ Recovered or | TheLBA has not yet been reassigned. [cl] 
unrecovered 
oh Yes No Raraversd The device server performed automatic read reassignment for the LBA (i.e., performed a reassign 
operation for the LBA and a write operation with recovered logical block data). Id) 
Ah Yes Yas Recovered The device server's attempt to perform automatic read reassignment failed. The logical block may 
or may not now have an uncorrectable error. [cl] 
5h Vas No Recavered The error was corrected by the device server rewriting the logical block without performing a reas- 
sign operation. 
Either: 
Recovered or | 2) an application client caused automatic write reassignment for the LBA with a command per- 
6h Yes Yes uinkecoversd forming a write operation; or 
b) the LBPRZ bit is set to one in the Logical Block Provisioning VPD page (see 5.2.19), and an appli- 
cation client caused an unmap operation for the LBA. [cl] 
Either: 
Recovered or | 2) an application client caused a reassign operation for the LBA with a REASSIGN BLOCKS com- 
7h Yes Yes mand; or 
unrecovered 
b) the LBPRZ bit is set to zero in the Logical Block Provisioning VPD page (see 5.2.19), and an appii- 
cation client caused an unmap operation for the LBA. [cl] 
Racovsredier: | 00 application client’s request for a reassign operation for the LBA with a REASSIGN BLOCKS com- 
8h Yes Yes arecoucea mand failed. The logical block referenced by the LBA may or may not still have an uncorrectable 
error. 
All Reserved. 
others 








[a] Based on the LOWIR bit in the Background Control mode page (see 5.3.7), “No” specifies that a Background Scan log parameter shall not 
be generated for the error and “Yes” specifies that a Background Scan log parameter shall be generated for the error. 


[b] Type of error detected while reading the logical block referenced by the LBA specified by the LOGICAL BLOCK ADDRESS field during a 
background scan operation. 


[c] The REASSIGN STATUS field in a given log parameter changes from 1h or 4h to 6h, 7h, or 8h when a reassign operation, write medium 
operation based on the rules for caching, or unmap operation for the LBA succeeds or when a reassign operation for the LBA fails. After the 
LBA is reassigned, any subsequent medium error occurring for the LBA is reported in a new log parameter with the same value in the LOG- 
ICAL BLOCK ADDRESS field as the value in the LOGICAL BLOCK ADDRESS field in the log parameter for the previous medium error for the 
LBA. 


[d] The ARRE bit in the Read-Write Error Recovery mode page (see 5.3.22) controls automatic read reassignment based on errors detected 
during all read operations, including those that are part of background scan operations. 








SENSE KEY, ADDITIONAL SENSE CODE, and the ADDITIONAL SENSE CODE QUALIFIER fields 


The SENSE KEY field, ADDITIONAL SENSE CODE field, and the ADDITIONAL SENSE CODE QUALIFIER field may contain a hierarchy of additional 
information relating to error conditions that occurred during background scanning. They are represented in the same format used by the sense 
data (see SPC-5). 


LOGICAL BLOCK ADDRESS field 
The LOGICAL BLOCK ADDRESS field indicates the LBA associated with the medium error. 
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5.2.5 Background Operation log page (15h/02h) 


5.2.5.1 Background Operation log page overview 


Using the format shown in table273, the Background Operation log page reports parameters that are specific to background 
operations. 


Table 283. Background Operation log page 
























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS (1) SPF (1b) PAGE CODE (15h) 
1 SUBPAGE CODE (02h) 
2 (MSB) 
PAGE LENGTH (n-3) 

3 (LSB) 

Background Operation parameter 
4 

Background Operation parameter [first] (if any) 

Background Operation parameter [last] (if any) 
n 














DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The disable save (DS) bit, the subpage format (SPF) bit, the PAGE CODE field, the SUBPAGE CODE field, and the PAGE LENGTH field are described 
in 5.2.2.1. 


SPF bit, PAGE CODE field, and SUBPAGE CODE field 

The SPF bit, the PAGE CODE field, and the SUBPAGE CODE field shall be set to the values shown in table 283 for the Background Operation log 
page. 

The parameter codes for the Background Operation log page are listed in table 284. 


Table 284 Background Operation log page parameter codes 


























Parameter code Description pan Reference eee 
0000h Background Operation Never 5.2.5.2 Mandatory 
All others Reserved 
[a] The keywords in this column - Always, Reset Only, and Never - are defined in 5.2.2.3. 
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5.2.5.2 Background Operation log parameter 
The Background Operation log parameter of the Background Operation log page has the format defined in table 285. 


Table 285 Background Operation log parameter format 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0000h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (4h) 
4 BO_STATUS 
5 

Reserved 

n 














PARAMETER CODE field 

The PARAMETER CODE field is described in 4.2.2.2.2 and shall be set to the value shown in table 285 for the Background Operation log param- 
eter. 

PARAMETER LENGTH field 

The PARAMETER LENGTH field is described in SPC-5 and shall be set to the value shown in table 285 for the Background Operation log param- 
eter. 

BO_STATUS field 

The background operation status (BO_STATUS) field indicates the type of background operation, if any, that is being performed by the device 


server as defined in table 286. 


Table 286 BO_STATUS Definitions 








Code Description 

00h No indication 

O1h No advanced background operation being performed 

02h Host initiated advanced background operation being performed 

03h Device initiated advanced background operation being performed 
All others Reserved 
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5.2.6 Cache Statistics page (37h/00h) 
Log Page code 37h specifies Cache Statistics page. The page format is shown in Table 288. 


Table 287 Parameter codes 





























Parameter code Description eerie 
Changeable [a] 
This parameter code represents the number of logical blocks that have been sent to | Reset 
0000h sig 
a SCSI initiator port. Only 
This parameter code represents the number of logical blocks that have been Reset 
0001h ; 5 is 
received from a SCSI initiator port. Only 
This parameter code represents the number of logical blocks read from the cache Reset 
0002h Saat 
memory that have been sent to a SCSI initiator port. Only 
This parameter code represents the number of READ and WRITE commands that Reset 
0003h ; Onl 
had data lengths equal or less than the current segment size. nly 
This parameter code represents the number of READ and WRITE commands that Reset 
0004h : Onl 
had data lengths greater than the current segment size. nly 
[a] The keywords in this column -- Always, Reset Only, and Never -- are defined in 5.2.2.3. 








Table 288 Cache Statistics page (37h) 






































Bit 7 0 
Byte 
0 DS SPF (Ob) PAGE CODE (37h) (see 5.1.1) 
1 SUBPAGE CODE(00h) (see 5.2.2.1) 
2 (MSB) 
PAGE LENGTH (see 5.1.1) 
3 (LSB) 
CACHE STATISTICS LOG PARAMETERS 
4 (MSB) 
PARAMETER CODE (see table 287) 
(LSB) 
PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
PARAMETER LENGTH 
PARAMETER VALUE 
(MSB) 
PARAMETER CODE (see table 287) 
(LSB) 
PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
PARAMETER LENGTH 
PARAMETER VALUE 
n 
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5.2.7 Environmental Limits log page (ODh/02h) 


5.2.7.1 Overview 


Using the format shown in table 290, the Environmental Limits log page provides information about the environmental limits of 
the logical unit using the parameter codes listed in table 289. 


The Environmental Reporting log page (see 5.2.8) shall be supported if the Environmental Limits log page is supported. Each log 
parameter in the Environmental Limits log page contains limits that are applied to the environmental measurement in the log 
parameter in the Environmental Reporting log page that has the same parameter code (e.g., parameter 0000h in this log page is 
associated with log parameter 0000h in the Environmental Reporting log page). 


Table 289 —_ Environmental Limits log page parameter codes 























Parameter code Description Resettable or Reference Support 

Changeable [al Required 
0000h - OOFFh Temperature Limits Always or Never 5.2.7.2 Optional 
0100h - 01FFh Relative Humidity Limits Always or Never 5.2.7.3 Optional 
All others Reserved 








[a] The keywords in this column -- Always, Reset Only, and Never -- are defined in 5.2.2.3. 


[b] The device server may support either Always or Never. If supporting Always, then the device server may round each field up or 
down as defined in 2.3. 


[c] If more than one Temperature Limits parameter is supported, each Temperature Limits parameter is associated with the tem- 
perature at a separate location. 

[d] If more than one Relative Humidity Report parameter is supported, each Relative Humidity Limits parameter is associated 
with the relative humidity at a separate location. 











The Environmental Limits log page has the format shown in table 290. 


Table 290 Environmental Limits log page 



































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (1b) PAGE CODE (0Dh) 
1 SUBPAGE CODE (02h) 
2 (MSB) 
PAGE LENGTH (n-3) 

3 (LSB) 

Environmental Limits log parameter 
4 

Environmental Limits log parameter [first] (if any) 

Environmental Limits log parameter [last] (if any) 
n 














DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 5.2.2 The SPF bit, PAGE CODE field, and SUB- 
PAGE CODE field shall be set as shown in table 290 for the Environmental Limits log page. 


The contents of each environmental limits log parameter depends on the value in its PARAMETER CODE field (see table 289). 
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The Temperature Limits log parameter has the format shown in table 291. 


Table 291 Temperature Limits log parameter 





Bit 7 6 5 4 3 2 1 0 
Byte 


























0 MSB 
PARAMETER CODE (see table 289) 





(LSB) 





PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 





PARAMETER LENGTH (08h) 





HIGH CRITICAL TEMPERATURE LIMIT TRIGGER 





HIGH CRITICAL TEMPERATURE LIMIT RESET 





LOW CRITICAL TEMPERATURE LIMIT RESET 





LOW CRITICAL TEMPERATURE LIMIT TRIGGER 





HIGH OPERATING TEMPERATURE LIMIT TRIGGER 





WOl/OIN|A/ Us Bl WIN] = 


HIGH OPERATING TEMPERATURE LIMIT RESET 





LOW OPERATING TEMPERATURE LIMIT RESET 











—=_=| = 
=—=| oO 


LOW OPERATING TEMPERATURE LIMIT TRIGGER 








PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.1 and shall be as shown in table 289 for the Temperature Limits log parameters. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1 and shall be set as shown in table 291 for the Temperature Limits log parameters. 


The temperature values reported in the Temperature Limits log parameters indicate a temperature in degrees Celsius. Negative values shall be 
indicated by two's complement notation. A value of -128 (i.e., 80h) specifies that there is no limit. 


HIGH CRITICAL TEMPERATURE LIMIT TRIGGER field 


The HIGH CRITICAL TEMPERATURE LIMIT TRIGGER field indicates the maximum temperature at this sensor for which the logical unit should be 
operated. If the EWASC bit is set to one in the Information Exceptions Control mode page (see SBC-4, SSC-4, or SMC-3) and the associated cur- 
rent temperature (see 5.2.8.2) is greater than the value in the HIGH CRITICAL TEMPERATURE LIMIT TRIGGER field, then the device server shall 
report an informational exception condition with the additional sense code set to WARNING - HIGH CRITICAL TEMPERATURE LIMIT EXCEEDED. 


HIGH CRITICAL TEMPERATURE LIMIT RESET field 
The HIGH CRITICAL TEMPERATURE LIMIT RESET field indicates the temperature at which the informational exception condition for a high criti- 
cal temperature limit, if any, shall be cleared. 


LOW CRITICAL TEMPERATURE LIMIT RESET field 


The LOW CRITICAL TEMPERATURE LIMIT RESET field indicates the temperature at which the informational exception condition for a low critical 
temperature limit, if any, shall be cleared. 


LOW CRITICAL TEMPERATURE LIMIT TRIGGER field 


The LOW CRITICAL TEMPERATURE LIMIT TRIGGER field indicates the minimum temperature at this sensor for which the logical unit should be 
operated. If the EWASC bit is set to one in the Information Exceptions Control mode page (see SBC-4, SSC-4, or SMC-3) and the associated cur- 
rent temperature (see 5.2.8.2) is less than the value in the LOW CRITICAL TEMPERATURE LIMIT TRIGGER field, then the device server shall report 
an informational exception condition with the additional sense code set to WARNING - LOW CRITICAL TEMPERATURE LIMIT EXCEEDED. 


HIGH OPERATING TEMPERATURE LIMIT TRIGGER field 


The HIGH OPERATING TEMPERATURE LIMIT TRIGGER field indicates the maximum temperature at this sensor for which the logical unit is capa- 
ble of operating continuously without degrading the reliability beyond manufacturer accepted limits. If the EWASC bit is set to one in the Infor- 
mation Exceptions Control mode page (see SBC-4, SSC-4, or SMC-3) and the associated current temperature (see 5.2.8.2) is greater than the 
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value of the HIGH OPERATING TEMPERATURE LIMIT TRIGGER field, then the device server shall report an informational exception condition with 
the additional sense code set to WARNING - HIGH OPERATING TEMPERATURE LIMIT EXCEEDED. 


HIGH OPERATING TEMPERATURE LIMIT RESET field 


The HIGH OPERATING TEMPERATURE LIMIT RESET field indicates the temperature at which the informational exception condition for the asso- 
ciated high critical temperature limit, if any, shall be cleared. 


LOW OPERATING TEMPERATURE LIMIT RESET field 


The LOW OPERATING TEMPERATURE LIMIT RESET field indicates the temperature at which the informational exception condition for the associ- 
ated low critical temperature limit, if any, shall be cleared. 


LOW OPERATING TEMPERATURE LIMIT TRIGGER field 


The LOW OPERATING TEMPERATURE LIMIT TRIGGER field indicates the minimum temperature at this sensor for which the logical unit is capable 
of operating continuously without degrading the logical unit's reliability beyond manufacturer accepted limits. If the EWASC bit is set to one in 
the Information Exceptions Control mode page (see SBC-4, SSC-4, or SMC-3) and the associated current temperature (see 5.2.8.2) is less than 
the value of the LOW OPERATING TEMPERATURE LIMIT TRIGGER field, then the device server shall report an informational exception condition 
with the additional sense code set to WARNING - LOW OPERATING TEMPERATURE LIMIT EXCEEDED. 


5.2.7.3 Relative Humidity Limits log parameter 
The Relative Humidity Limits log parameter has the format shown in table 292. 


Table 292 Relative Humidity Limits log parameter 







































































Bit 7 6 5 4 3 2 1 0 
Byte 

oO (MSB) 

PARAMETER CODE (see table 289) 

1 (LSB) 

2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 

3 PARAMETER LENGTH (08h) 

4 HIGH CRITICAL RELATIVE HUMIDITY LIMIT TRIGGER 

5 HIGH CRITICAL RELATIVE HUMIDITY LIMIT RESET 

6 LOW CRITICAL RELATIVE HUMIDITY LIMIT RESET 

7 LOW CRITICAL RELATIVE HUMIDITY LIMIT TRIGGER 

8 HIGH OPERATING RELATIVE HUMIDITY LIMIT TRIGGER 

9 HIGH OPERATING RELATIVE HUMIDITY LIMIT RESET 

10 LOW OPERATING RELATIVE HUMIDITY LIMIT RESET 

11 LOW OPERATING RELATIVE HUMIDITY LIMIT TRIGGER 





PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.1 and shall be as shown in table 289 for the Temperature Limits log parameters. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1 and shall be set as shown in table 292 for the Temperature Limits log parameters. 


The relative humidity limit values used in the Relative Humidity Limits log parameters are shown in table 299. 


Table 293 _—Relative humidity limit values 





Value Description 





0 to 100 Relative humidity 





101 to 254 | Reserved 





255 No relative humidity limit 
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HIGH CRITICAL RELATIVE HUMIDITY LIMIT TRIGGER field 


The HIGH CRITICAL RELATIVE HUMIDITY LIMIT TRIGGER field indicates the maximum relative humidity at this sensor for which the logical unit 
should be operated. If the EWASC bit is set to one in the Information Exceptions Control mode page (see SBC-4, SSC-4, or SMC-3) and the asso- 
ciated current relative humidity (see 5.2.7.3) is greater than the value in the HIGH CRITICAL RELATIVE HUMIDITY LIMIT TRIGGER field, then the 
device server shall report an informational exception condition with the additional sense code set to WARNING - HIGH CRITICAL HUMIDITY 
LIMIT EXCEEDED. 


HIGH CRITICAL RELATIVE HUMIDITY LIMIT RESET field 


The HIGH CRITICAL RELATIVE HUMIDITY LIMIT RESET field indicates the relative humidity at which the informational exception condition for a 
high critical relative humidity limit, if any, shall be cleared. 


LOW CRITICAL RELATIVE HUMIDITY LIMIT RESET field 


The LOW CRITICAL RELATIVE HUMIDITY LIMIT RESET field indicates the relative humidity at which the informational exception condition for a 
low critical relative humidity limit, if any, shall be cleared. 


LOW CRITICAL RELATIVE HUMIDITY LIMIT TRIGGER field 


The LOW CRITICAL RELATIVE HUMIDITY LIMIT TRIGGER field indicates the minimum relative humidity at this sensor for which the logical unit 
should be operated. If the EWASC bit is set to one in the Information Exceptions Control mode page (see SBC-4, SSC-4, or SMC-3) and the asso- 
ciated current relative humidity (see 5.2.7.3) is less than the value in the LOW CRITICAL RELATIVE HUMIDITY LIMIT TRIGGER field, then the 
device server shall report an informational exception condition with the additional sense code set to WARNING - LOW CRITICAL HUMIDITY 
LIMIT EXCEEDED. 


HIGH OPERATING RELATIVE HUMIDITY LIMIT TRIGGER field 


The HIGH OPERATING RELATIVE HUMIDITY LIMIT TRIGGER field indicates the maximum relative humidity at this sensor for which the logical 
unit is capable of operating continuously without degrading the reliability beyond manufacturer accepted limits. If the EWASC bit is set to one 
in the Information Exceptions Control mode page (see SBC-4, SSC-4, or SMC-3) and the associated current relative humidity (see 5.2.7.3) is 
greater than the value of the HIGH OPERATING RELATIVE HUMIDITY LIMIT TRIGGER field, then the device server shall report an informational 
exception condition with the additional sense code set to WARNING - HIGH OPERATING HUMIDITY LIMIT EXCEEDED. 


HIGH OPERATING RELATIVE HUMIDITY LIMIT RESET field 

The HIGH OPERATING RELATIVE HUMIDITY LIMIT RESET field indicates the relative humidity at which the informational exception condition for 
the associated high critical relative humidity limit, if any, shall be cleared. 

LOW OPERATING RELATIVE HUMIDITY LIMIT RESET field 

The LOW OPERATING RELATIVE HUMIDITY LIMIT RESET field indicates the relative humidity at which the informational exception condition for 
the associated low critical relative humidity limit, if any, shall be cleared. 

LOW OPERATING RELATIVE HUMIDITY LIMIT TRIGGER field 


The LOW OPERATING RELATIVE HUMIDITY LIMIT TRIGGER field indicates the minimum relative humidity at this sensor for which the logical unit 
is capable of operating continuously without degrading the logical unit's reliability beyond manufacturer accepted limits. If the EWASC bit is 
set to one in the Information Exceptions Control mode page (see SBC-4, SSC-4, or SMC-3) and the associated current relative humidity (see 
5.2.7.3) is less than the value of the LOW OPERATING RELATIVE HUMIDITY LIMIT TRIGGER field, then the device server shall report an informa- 
tional exception condition with the additional sense code set to WARNING - LOW OPERATING HUMIDITY LIMIT EXCEEDED. 
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5.2.8 Environmental Reporting log page (ODh/01h) 


5.2.8.1 Overview 


Using the format shown in table 295, the Environmental Reporting log page provides information about the environmental 
conditions of the logical unit using the parameter codes listed in table 294. 


Table 294 Environmental Reporting log page parameter codes 























Parameter code Description Resettable or Reference Support 
Changeable !7! 

0000h - OOFFh Temperature Report /«! Never 5.2.8.2 Atleast one tl 

0100h - 01FFh Relative Humidity Report !41 Never 5.2.7.3 Optional 

All others Reserved 








[a] The keywords in this column -- Always, Reset Only, and Never -- are defined in 5.2.2.3. 


[b] If the Environmental Reporting log page is supported, at least one of the parameter codes listed in this table shall be sup- 
ported. 


[c] If more than one Temperature Report parameter is supported, then each Temperature Report parameter represents the tem- 
perature at a separate location. 


[d] If more than one Relative Humidity Report parameter is supported, then each Relative Humidity Report parameter represents 
the temperature at a separate location. 











The Environmental Reporting log page has the format shown in table 295. 


Table 295 Environmental Reporting log page 






























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (1b) PAGE CODE (0Dh) 
1 SUBPAGE CODE (01h) 
2 (MSB) 
PAGE LENGTH (n-3) 

3 (LSB) 

Environmental Reporting log parameter 
4 

Environmental Reporting log parameter [first] (if any) 

Environmental Reporting log parameter [last] (if any) 
n 














DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 5.2.2 The SPF bit, PAGE CODE field, and SUB- 
PAGE CODE field shall be set as shown in table 295 for the Environmental Reporting log page. 


The contents of each environmental reporting log parameter depends on the value in its PARAMETER CODE field (see table 294). 


SCSI Commands Reference Manual, Rev. J 324 


www.seagate.com 


5.2.8.2 Temperature Report log parameter 


Parameters for direct access devices 


The Temperature Report log parameter has the format shown in table 296. 


Table 296 Temperature Report log parameter 




































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (see table 289) 

1 (LSB) 

2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 

3 PARAMETER LENGTH (08h) 

4 Reserved 

5 TEMPERATURE 

6 LIFETIME MAXIMUM TEMPERATURE 

7 LIFETIME MINIMUM TEMPERATURE 

8 MAXIMUM TEMPERATURE SINCE POWER ON 

9 MINIMUM TEMPERATURE SINCE POWER ON 

10 

Reserved 
11 








PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.1 and shall be as shown in table 294 for the Temperature Report log parameters. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1 and shall be set as shown in table 296 for the Temperature Report log parameters. 


The temperature values reported in the Temperature Report log parameters indicate a temperature in degrees Celsius. Negative values shall be 
indicated by two's complement notation. A value of -128 (i.e., 80h) specifies that temperature is not valid. 


TEMPERATURE field 
The TEMPERATURE field indicates the most recently detected temperature by the temperature sensor associated with this log parameter. 


LIFETIME MAXIMUM TEMPERATURE field 


The LIFETIME MAXIMUM TEMPERATURE field indicates the maximum temperature detected by the temperature sensor associated with this log 
parameter since the time of manufacture. 


LIFETIME MINIMUM TEMPERATURE field 
The LIFETIME MINIMUM TEMPERATURE field indicates the minimum temperature detected by the temperature sensor associated with this log 
parameter since the time of manufacture. 


MAXIMUM TEMPERATURE SINCE POWER ON field 
The MAXIMUM TEMPERATURE SINCE POWER ON field indicates the maximum temperature detected by the temperature sensor associated 
with this log parameter since the most recent power on. 


MINIMUM TEMPERATURE SINCE POWER ON field 


The MINIMUM TEMPERATURE SINCE POWER ON field indicates the minimum temperature detected by the temperature sensor associated with 
this log parameter since the most recent power on. 
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Relative Humidity Report log parameter 


The Relative Humidity Report log parameter has the format shown in table 297. 






























































Table 297 = Relative Humidity Report log parameter 

Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (see table 289) 

1 (LSB) 

2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 

3 PARAMETER LENGTH (08h) 

4 Reserved 

5 RELATIVE HUMIDITY 

6 LIFETIME MAXIMUM RELATIVE HUMIDITY 

7 LIFETIME MINIMUM RELATIVE HUMIDITY 

8 MAXIMUM RELATIVE HUMIDITY SINCE POWER ON 

9 MINIMUM RELATIVE HUMIDITY SINCE POWER ON 

10 

a Reserved 














PARAMETER CODE field 


The PARAMETER CODE field is described in 5.2.2.2.1 and shall be as shown in table 294 for the Relative Humidity Report log parameters. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1 and shall be set as shown in table 297 for the Relative Humidity Report log parameters. 


The relative humidity limit values used in the Relative Humidity Limits log parameters are shown in table 298. 














Table 298 _ Relative humidity reporting values 
Value Description 
0 to 100 Relative humidity 
101 to 254 | Reserved 
255 No valid relative humidity 
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RELATIVE HUMIDITY field 

The RELATIVE HUMIDITY field indicates the most recently detected relative humidity for the humidity sensor associated with this log parame- 
ter. 

LIFETIME MAXIMUM RELATIVE HUMIDITY field 

The LIFETIME MAXIMUM RELATIVE HUMIDITY field indicates the maximum relative humidity detected by the humidity sensor associated with 
this log parameter since the time of manufacture. 

LIFETIME MINIMUM RELATIVE HUMIDITY field 

The LIFETIME MINIMUM RELATIVE HUMIDITY field indicates the minimum relative humidity detected by the humidity sensor associated with 
this log parameter since the time of manufacture. 

MAXIMUM RELATIVE HUMIDITY SINCE POWER ON field 


The MAXIMUM RELATIVE HUMIDITY SINCE POWER ON field indicates the maximum relative humidity detected by the humidity sensor associ- 
ated with this log parameter since the most recent power on. 


MINIMUM RELATIVE HUMIDITY SINCE POWER ON field 


The MINIMUM RELATIVE HUMIDITY SINCE POWER ON field indicates the minimum relative humidity detected by the humidity sensor associ- 
ated with this log parameter since the most recent power on. 
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5.2.9 Error counter log pages (WRITE, READ, and VERIFY) 


This subclause defines the error counter log pages (see table 299). 


Table 299 _ Error counter log page codes 





Page Code Loge Page Name 





03h/00h Read Error Counter 





05h/00h Verify Error Counter 





02h/00h Write Error Counter 














Table 300 defines the parameter codes for the error counter log pages. 


Table 300 Parameter codes for error counter log pages 





Parameter D nha Resettable or 

code een Changeable 2! 
Errors corrected without substantial delay. An error correction was applied to get perfect data (a.k.a, ECC | Reset Only 
on-the-fly). “Without Substantial Delay” means the correction did not postpone reading of later sectors 
(e.g., a revolution was not lost). The counter is incremented once for each logical block that requires cor- 
rection. Two different blocks corrected during the same command are counted as two events. 


0000h 


Errors corrected with possible delays. An error code or algorithm (e.g.,ECC, checksum) is applied in order | Reset Only 
to get perfect data with substantial delay. “With possible delay” means the correction took longer than a 
sector time so that reading/writing of subsequent sectors was delayed (e.g, a lost revolution). The 
counter is incremented once for each logical block that requires correction. A block with a double error 
that is correctable counts as one event and two different blocks corrected during the same command 
count as two events. 


0001h 





Total (e.g., rewrites or rereads). This parameter code specifies the counter counting the number of errors | Reset Only 
that are corrected by applying retries. This counts errors recovered, not the number of retries. If five 
retries were required to recover one block of data, the counter increments by one, not five. The counter 
is incremented once for each logical block that is recovered using retries. If an error is not recoverable 
while applying retries and is recovered by ECC, it isn’t counted by this counter; it will be counted by the 
counter specified by parameter code 01h-Error Corrected With Possible Delay. 


0002h 


Total errors corrected. This counter counts the total of parameter code errors 00h, 01h, and 02h. There is | Reset Only 
0003h to be no “double counting” of data errors among these three counters. The sum of all correctable errors 
can be reached by adding parameter code 01h and 02h errors, not by using this total. 





Total times correction algorithm processed. This parameter code specifies the counter that counts the Reset Only 
total number of retries, or “times the retry algorithm is invoked.” If after five attempts a counter 02h type 
error is recovered, then five is added to this counter. If three retries are required to get a stable ECC syn- 














0004h 
drome before a counter 01h type error is corrected, then those three retries are also counted here. The 
number of retries applied to unsuccessfully recover an error (counter 06h type error) are also counted by 
this counter. 
Total bytes processed. This parameter code specifies the counter that counts the total number of bytes | Reset Only 
0005h either successfully or unsuccessfully read, written, or verified (depending on the log page) from the 
drive. If a transfer terminates early because of an unrecoverable error, only the logical blocks up to and 
including the one with the unrecoverable error are counted. 
0006h Total uncorrected errors. This parameter code specifies the counter that contains the total number of Reset Only 
blocks for which an uncorrected data error has occurred. 
0007h - 7FFFh| Reserved Reset Only 
8000h - FFFFh| Vendor specific Reset Only 














[a] The keywords in this column -- Always, Reset Only, and Never -- are defined in 5.2.2.3. 
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The exact definition of the error counters is not part of this manual. These counters should not be used to compare products because the prod- 
ucts may define errors differently. 


Table 301 __— Error counter log page 



































Bit 7 6 5 4 3 2 1 0 
Byte 

Oo DS (1) SPF (0) PAGE CODE (see table 299) 

1 SUBPAGE CODE (00h) 

2 (MSB) 





PAGE LENGTH (n-3) 
3 (LSB) 


Error counter log parameter 








4 (MSB) 





PARAMETER CODE (see table 300) 
(LSB) 





PARAMETER CONTROL BYTE - bounded data counter log parameter (see 5.2.2.2.2.2) 
PARAMETER LENGTH 
PARAMETER VALUE 

















Error counter log parameter 





(MSB) 





PARAMETER CODE (see table 300) 
(LSB) 





PARAMETER CONTROL BYTE - bounded data counter log parameter (see 5.2.2.2.2.2) 
PARAMETER LENGTH 
n PARAMETER VALUE 




















The log page format is defined in 5.2.2. A log page may return one or more log parameters that record events defined by the 
parameter codes. 
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5.2.10 Factory Log page (3Eh/00h) 
Log page code 3Eh specifies factory status parameters (see table 302). 


Table 302 Factory Log page (3Eh) 













































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (0b) PAGE CODE (3Eh) 
1 SUBPAGE CODE(00h) 
2 (MSB) 
PAGE LENGTH 
3 (LSB) 
4 (MSB) 
PARAMETER CODE! [2] 
(LSB) 
PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
PARAMETER LENGTH 
PARAMETER VALUE 
(MSB) 
PARAMETER CODE 
(LSB) 
PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
PARAMETER LENGTH 
PARAMETER VALUE 














[1] PARAMETER CODE 0000h-Power-on Time. This parameter code represents the number of drive power-on minutes. 


[2] PARAMETER CODE O8h. This parameter reports the time, in minutes, to the next scheduled interrupt for a S.M.A.R.T. mea- 
surement. 


DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field 
The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field are described in 5.2.2. 
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5.2.11 Format Status log page (08h/00h) 


5.2.11.1 Format Status log page overview 


Using the format shown table 175, the Format Status log page reports information about the most recent successful format 
operation and the state of the direct access block device since that operation was performed. The parameter codes for the 
Format Status log page are listed in table 303. 


Table 303 Format Status log page parameter codes 















































Parameter code Description EN Reference periea 
0000h Format Data Out Never 5.2.8.2 Mandatory 
0001h Grown Defects During Certification Never 5.2.7.3 Mandatory 
0002h Total Blocks Reassigned During Format Never 5.2.8.2 Mandatory 
0003h Total New Blocks Reassigned Never 5.2.7.3 Mandatory 
0004h Power On Minutes Since Format Never 5.2.8.2 Mandatory 

0005h - 7FFFh Reserved 
8000h - FFFFh Vendor Specific Optional 
[a] The keywords in this column-- Always, Reset Only, and Never -- are defined in 5.2.2.3. 


The Format Status log page has the format defined in table 304. 


Table 304 Format Status log page 





















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS (1b) SPF (0b) PAGE CODE (08h) 
1 SUBPAGE CODE (00h) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 
Format Status log parameter 
4 
Format Status log parameter [first] (if any) 
Format Status log parameter [last] (if any) 
n 














DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 5.2.2. The DS bit, the SPF bit, the PAGE CODE 
field, and the SUBPAGE CODE field shall be set to the values shown in table 304 for the Format Status log page. 


If a format operation has never been performed by the logical unit, then the log parameter for each Format Status log parameter 
listed in table 303 is not defined by this standard. If a device server begins a format operation, then the device server shall set 
each byte of the log parameter data (i.e., bytes four to n of the log parameter), if any, to FFh for each Format Status log parameter 
(e.g., if the PARAMETER LENGTH field is set to 02h, then the log parameter data is set to FFFFh). 
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If the most recent format operation failed or the information for a Format Status log parameter is not available, then the device 
server shall return FFh in each byte of the log parameter data (i.e., bytes four to n of the log parameter), if any, for the Format 
Status log parameter (e.g., if the PARAMETER LENGTH field is set to 04h, then the log parameter data shall be set to FFFF_FFFFh). 
The device server shall set each Format Status log parameter to be a multiple of four bytes. 


5.2.11.2 Format Data Out log parameter 
The Format Data Out log parameter of the Format Status log page has the format defined in table 305. 


Table 305 Format Data Out log parameter format 





























Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0000h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (n-3) 
4 (MSB) 

FORMAT DATA OUT 

n (LSB) 








PARAMETER CODE field 
The PARAMETER CODE field is described in 4.2.2.2.2 and shall be set to the value shown in table 305 for the Format Data Out log parameter. 


TSD bit 


The target save disable (TSD) bit (see SPC-5) shall be set to zero for the Format Data Out log parameter, indicating that the logical unit saves the 
Format Data Out log parameter at vendor specific intervals without any request from an application client. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in SPC-5 and shall be set to the value shown in table 305 for the Format Data Out log parameter. 


FORMAT DATA OUT field 
After a successful format operation, the FORMAT DATA OUT field contains the FORMAT UNIT parameter list (see table 38). 
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5.2.11.3 Grown Defects During Certification log parameter 
The Grown Defects During Certification log parameter for the Format Status log page has the format defined in table 306. 


Table 306 Grown Defects During Certification log parameter format 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0001h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (08h) 
4 (MSB) 

GROWN DEFECTS DURING CERTIFICATION 

n (LSB) 











PARAMETER CODE field 

The PARAMETER CODE field is described in 4.2.2.2.2 and shall be set to the value shown in table 306 for the Grown Defects During Certification 
log parameter. 

TSD bit 


The target save disable (TSD) bit (see SPC-5) shall be set to zero for the Grown Defects During Certification log parameter, indicating that the 
logical unit saves the Grown Defects During Certification log parameter at vendor specific intervals without any request from an application cli- 
ent. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in SPC-5 and shall be set to the value shown in table 306 for the Grown Defects During Certification 
log parameter. 


GROWN DEFECTS DURING CERTIFICATION field 


After a successful format operation during which certification was performed, the GROWN DEFECTS DURING CERTIFICATION field shall indicate 
the number of defects detected as a result of performing the certification. The value in the GROWN DEFECTS DURING CERTIFICATION field 
count reflects only those defects detected and replaced during the successful format operation that were not already part of the PLIST or GLIST. 


After a successful format operation during which certification was not performed, the GROWN DEFECTS DURING CERTIFICATION field shall be 
set to zero. 
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5.2.11.4 Total Blocks Reassigned During Format log parameter 
The Grown Defects During Certification log parameter for the Format Status log page has the format defined in table 307. 


Table 307 ‘Total Blocks Reassigned During Format log parameter format 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0002h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (08h) 
4 (MSB) 

TOTAL BLOCKS REASSIGNED DURING FORMAT 

n (LSB) 











PARAMETER CODE field 


The PARAMETER CODE field is described in 4.2.2.2.2 and shall be set to the value shown in table 307 for the Total Blocks Reassigned During For- 
mat log parameter. 


TSD bit 


The target save disable (TSD) bit (see SPC-5) shall be set to zero for the Total Blocks Reassigned During Format log parameter, indicating that 
the logical unit saves the Total Blocks Reassigned During Format log parameter at vendor specific intervals without any request from an appli- 
cation client. 


PARAMETER LENGTH field 

The PARAMETER LENGTH field is described in SPC-5 and shall be set to the value shown in table 307 for the Total Blocks Reassigned During For- 
mat log parameter. 

TOTAL BLOCKS REASSIGNED DURING FORMAT field 


The TOTAL BLOCKS REASSIGNED DURING FORMAT field contains the count of the total number of logical blocks that were reassigned during 
the most recent successful format operation. 
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5.2.11.5 Total New Blocks Reassigned log parameter 
The Total New Blocks Reassigned log parameter for the Format Status log page has the format defined in table 308. 


Table 308 Total New Blocks Reassigned log parameter format 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0003h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (08h) 
4 (MSB) 

TOTAL NEW BLOCKS REASSIGNED 

n (LSB) 











PARAMETER CODE field 
The PARAMETER CODE field is described in 4.2.2.2.2 and shall be set to the value shown in table 308 for the Total New Blocks Reassigned log 


parameter. 

TSD bit 

The target save disable (TSD) bit (see SPC-5) shall be set to zero for the Total New Blocks Reassigned log parameter, indicating that the logical 
unit saves the Total New Blocks Reassigned log parameter at vendor specific intervals without any request from an application client. 
PARAMETER LENGTH field 

The PARAMETER LENGTH field is described in SPC-5 and shall be set to the value shown in table 308 for the Total New Blocks Reassigned log 
parameter. 

TOTAL NEW BLOCKS REASSIGNED field 


The TOTAL NEW BLOCKS REASSIGNED field contains a count of the total number of logical blocks that have been reassigned since the comple- 
tion of the most recent successful format operation. 
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5.2.11.6 Power On Minutes Since Format log parameter 
The Power On Minutes Since Format log parameter for the Format Status log page has the format defined in table 309. 


Table 309 Power On Minutes Since Format log parameter format 





















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0004h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (08h) 
4 (MSB) 

POWER ON MINUTES SINCE FORMAT 

n (LSB) 








PARAMETER CODE field 

The PARAMETER CODE field is described in 4.2.2.2.2 and shall be set to the value shown in table 309 for the Power On Minutes Since Format log 
parameter. 

TSD bit 

The target save disable (TSD) bit (see SPC-5) shall be set to zero for the Power On Minutes Since Format log parameter, indicating that the logi- 
cal unit saves the Power On Minutes Since Format log parameter at vendor specific intervals without any request from an application client. 
PARAMETER LENGTH field 

The PARAMETER LENGTH field is described in SPC-5 and shall be set to the value shown in table 309 for the Power On Minutes Since Format log 
parameter. 

POWER ON MINUTES SINCE FORMAT field 


The POWER ON MINUTES SINCE FORMAT field contains the unsigned number of usage minutes (i.e., minutes with power applied regardless of 
power state) that have elapsed since the most recent successful format operation. 
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5.2.12 Informational Exceptions log page (2Fh/00h) 


The Informational Exceptions log page (see table 310) provides a place for reporting detail about informational exceptions. The 
page code for the Informational Exceptions log page is 2Fh. 


Table 310 defines the parameter codes. 


Table 310 Informational exceptions parameter codes 








Parameter code Description Hesettableicy Reference | Support 
e Changeable !7! Required 
0000h Informational exceptions general parameter data Reset Only 5.2.9 Mandatory 











0001h - FFFFh Vendor specific 











[a] The keywords in this column - Always, Reset Only, and Never - are defined in 5.2.2.3. 








The Informational Exceptions log page has the format shown in table 311. 


Table 311 = Informational Exceptions log page 



























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (Ob) PAGE CODE (2Fh) 
1 SUBPAGE CODE (00h) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 
INFORMATIONAL EXCEPTIONS PARAMETERS 
4 FIRST INFORMATIONAL EXCEPTIONS LOG PARAMETER 
n LAST INFORMATIONAL EXCEPTIONS LOG PARAMETER 





DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field 


The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field are described in 5.2.2. 
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The informational exceptions general parameter data page has the format shown in table 312. 


Table 312 Informational exceptions general parameter data 
























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PARAMETER CODE (0000h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (N-3) 
4 INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE 
5 INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE QUALIFIER 
6 MOST RECENT TEMPERATURE READING 
7 VENDOR HDA TEMPERATURE TRIP POINT 
8 MAXIMUM TEMPERATURE 
9 
siese Vendor specific 
11 











PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2. The parameter length shall be at least 04h. 


INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE field 

If the INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE field contains zero, no informational exception condition is pending and con- 
tents of the INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE QUALIFIER field are unspecified. If the INFORMATIONAL EXCEPTION ADDI- 
TIONAL SENSE CODE field contains any value other than zero, an informational exception condition exists that has an additional sense code 
indicated by INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE field and an ADDITIONAL SENSE CODE QUALIFIER indicated by the INFOR- 
MATIONAL EXCEPTION ADDITIONAL SENSE CODE QUALIFIER field. 


INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE QUALIFIER field 


The INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE QUALIFIER field indicates detailed information related to the condition reported in 
the INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE field. If the condition is reported by the device server, the value returned shall be as 
defined in 2.4.1.5. If the device server does not have detailed information related to the reported condition, the INFORMATIONAL EXCEPTION 
ADDITIONAL SENSE CODE QUALIFIER field shall be set to zero. 


MOST RECENT TEMPERATURE READING field 


The MOST RECENT TEMPERATURE READING field indicates the temperature in degrees Celsius of the SCSI target device at the 
time the LOG SENSE command is performed. Temperatures equal to or less than zero degrees Celsius shall be indicated by a 
value of zero. If the device server is unable to detect a valid temperature because of a sensor failure or other condition, the value 
returned shall be FFh. The temperature should be reported with an accuracy of plus or minus three Celsius degrees while the 
device is operating at a steady state within the environmental limits specified for the device. 


VENDOR HDA TEMPERATURE TRIP POINT field 


This field indicates the drive HDA temperature, in degrees Celsius, at which the drive will post a status with Sense Key of RECOVERED ERROR or 
UNIT ATTENTION and the additional sense code set to WARNING -- SPECIFIED TEMPERATURE EXCEEDED. 


MAXIMUM TEMPERATURE 


Maximum Temperature field is the maximum temperature in degrees Celsius measured and logged by the device. This parameter value never 
decreases. The parameter content of this field ranges from 00h to FFh. 
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5.2.13 Logical Block Provisioning log page (OCh/00h) 


5.2.13.1 Logical Block Provisioning log page overview 


Using the format defined in table182, the Logical Block Provisioning log page reports the logical block provisioning status of the 
logical unit. The parameter codes for the Logical Block Provisioning log page are listed in table 313. 


Table 313 Logical Block Provisioning log page parameters 




































































Parameter code! | Description eee a Reference eet 
Resources that are associated with thresholds (0000h to OOFFh) 
0000h Reserved 
0001h Available LBA Mapping Resource Count Never 5.2.13.1 
0002h Used LBA Mapping Resource Count Never 5.2.13.1 Optional !! 
0003h Available Provisioning Resource Percentage Never 5.2.13.1 
0004h - OOFFh Reserved 
Resources that are not associated with thresholds (0000h to OOFFh) 
0100h De-duplicated LBA Resource Count Never 5.2.13.1 
0101h Compressed LBA Resource Count Never 5.2.13.1 Optional 
0102h Total Efficiency LBA Resource Count Never 5.2.13.1 
0103h - FFEFh Reserved 
FFFOh - FFFFh Vendor Specific 
[a] Parameter codes 0000h to OOFFh are coordinated with the THRESHOLD RESOURCE field in the threshold descriptor of the 
Logical Block Provisioning mode page (see 5.3.19). 
[b] The keywords in this column - Always, Reset Only, and Never - are defined in 5.2.2.3. 
[c] If this log page is supported, then at least one parameter shall be supported. A logical block provisioning log parameter in 
the range 0001h to OOFFh should be provided to report resource usage for each threshold resource for which a threshold 
descriptor in the Logical Block Provisioning mode page (see 5.3.19) is available. 





The Logical Block Provisioning log page has the format defined in table 314. 


Table 314 Logical block provisioning log page 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 DS (1b) SPF (Ob) PAGE CODE (0Ch) 

1 SUBPAGE CODE (00h) 

2 (MSB) 

PAGE LENGTH (n-3) 
3 (LSB) 
Logical block provisioning log parameter 
4 
Logical block provisioning log parameter [first] (if any) (see table 313) 

— Logical block provisioning log parameter [last] (if any) (see table 313) 

n 














DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 5.2.2. The DS bit, the SPF bit, the PAGE CODE 
field, and the SUBPAGE CODE field shall be set to the values shown in table 314 for the Logical Block Provisioning log page. 
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5.2.13.2. Available LBA Mapping Resource Count log parameter 


5.2.13.2.1 Available LBA Mapping Resource Count log parameter overview 


The Available LBA Mapping Resource Count log parameter of the Logical Block Provisioning log page has the format defined in 
table 315 


Table 315 Available LBA Mapping Resource Count log parameter format 



























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0001h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (08h) 
4 (MSB) 

RESOURCE COUNT 
7 (LSB) 
8 Reserved SCOPE 
9 
Reserved 

11 














PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.1 and shall be as shown in table 315 for the Available LBA Mapping Resource Count log 
parameters. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1 and shall be set as shown in table 315 for the Available LBA Mapping Resource Count log 
parameters. 


RESOURCE COUNT field 
The RESOURCE COUNT field indicates an estimate of the number of Available LBA mapping resources and is defined in 5.2.13.2.2. 


SCOPE field 
The SCOPE field indicates the scope to which the RESOURCE COUNT field applies and is defined in table 316. 


Table 316 SCOPE field 














Code Description 
00b The scope of the resource count is not reported. 
01b The RESOURCE COUNT field indicates a resource that is dedicated to the logical unit. Usage of resources on 
other logical units does not impact the resource count. 
10b The resource count field indicates resources that may or may not be dedicated to any logical unit including 


the addressed logical unit. Usage of resources on other logical units may impact the resource count. 


11b Reserved 
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5.2.13.2.2 RESOURCE COUNT field 


The RESOURCE COUNT field indicates an estimate of the number of LBA resources expressed as a number of threshold sets for 
the threshold resource indicated by the parameter code value. The nominal number of LBA resources is calculated as follows: 


LBA resources = resource count x threshold set size 


where: resource count is the value in the RESOURCE COUNT field; and 

threshold set size is the number of LBAs in each threshold set (i.e., 2 (threshold exponent) | Bag 
where the threshold exponent is indicated in the Logical Block Provisioning 
VPD page). 


5.2.13.3. Used LBA Mapping Resource Count log parameter 


The Used LBA Mapping Resource Count log parameter of the Logical Block Provisioning log page has the format defined in table 
317 


Table 317 Used LBA Mapping Resource Count log parameter format 















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0002h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (08h) 
4 (MSB) 

RESOURCE COUNT 
7 (LSB) 
8 Reserved SCOPE 
9 
Reserved 

11 














PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.1 and shall be as shown in table 317 for the Used LBA Mapping Resource Count log parame- 
ters. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1 and shall be set as shown in table 317 for the Used LBA Mapping Resource Count log 
parameters. 


RESOURCE COUNT field 
The RESOURCE COUNT field indicates an estimate of the number of Used LBA Mapping Resource and is defined in 5.2.13.2.2. 


SCOPE field 
The SCOPE field indicates the scope to which the RESOURCE COUNT field applies and is defined in table 316. 


SCSI Commands Reference Manual, Rev. J 341 


www.seagate.com Parameters for direct access devices 


5.2.13.4 Available Provisioning Resource Percentage log parameter 


5.2.13.4.1 Available Provisioning Resource Percentage log parameter overview 


The Available Provisioning Resource Percentage log parameter of the Logical Block Provisioning log page has the format defined 
in table 318 


Table 318 Available Provisioning Resource Percentage log parameter format 






























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PARAMETER CODE (0003h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (08h) 
4 (MSB) 
RESOURCE COUNT 

5 (LSB) 
6 

Reserved 
7 
8 Reserved SCOPE 
9 

Reserved 
11 














PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.1 and shall be as shown in table 318 for the Available Provisioning Resource Percentage log 
parameters. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1 and shall be set as shown in table 318 for the Available Provisioning Resource Percent- 
age log parameters. 


RESOURCE COUNT field 
The RESOURCE COUNT field indicates an estimate of the number of Available Provisioning resources and is defined in 5.2.13.4.2. 


SCOPE field 
The SCOPE field indicates the scope to which the RESOURCE COUNT field applies and is defined in table 316. 


5.2.13.4.2 RESOURCE COUNT field 


The RESOURCE COUNT field (see table 319) contains an estimate of the percentage of resources available for allocation to LBAs 
as a percentage of the manufacturer's total resources available for allocation. The units for the reported values are percent and 


range from 0% to 100%. 


Table 319 RESOURCE COUNT field 





Code Description 
Oto 100 | 0% to 100% of the provisioning resources of the logical unit are available 








All others | Reserved 
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5.2.13.5 De-duplicated LBA Resource Count log parameter 


The De-duplicated LBA Resource Count log parameter of the Logical Block Provisioning log page (see table 320) contains 
information about de-duplicated LBA resources. 


Table 320 De-duplicated LBA Resource Count log parameter format 






































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0100h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (08h) 
4 (MSB) 

RESOURCE COUNT 
7 (LSB) 
8 Reserved SCOPE 
9 
Reserved 

11 














PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.1 and shall be as shown in table 320 for the De-duplicated LBA Resource Count log parame- 
ters. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1 and shall be set as shown in table 320 for the De-duplicated LBA Resource Count log 
parameters. 


RESOURCE COUNT field 
The RESOURCE COUNT field indicates an estimate of the number of LBA resources made available as a result of de-duplication and is defined in 
5.2.13.4.2. 


SCOPE field 
The SCOPE field indicates the scope to which the RESOURCE COUNT field applies and is defined in table 316. 


SCSI Commands Reference Manual, Rev. J 343 


www.seagate.com Parameters for direct access devices 


5.2.13.6 Compressed LBA Resource Count log parameter 


The Compressed LBA Resource Count log parameter of the Logical Block Provisioning log page (see table 321) contains 
information about compressed LBA resources. 


Table 321 Compressed LBA Resource Count log parameter format 






































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0101h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (08h) 
4 (MSB) 

RESOURCE COUNT 
7 (LSB) 
8 Reserved SCOPE 
9 
Reserved 

11 














PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.1 and shall be as shown in table 321 for the Compressed LBA Resource Count log parameters. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1 and shall be set as shown in table 321 for the Compressed LBA Resource Count log 
parameters. 


RESOURCE COUNT field 
The RESOURCE COUNT field indicates an estimate of the number of LBA resources made available as a result of compression and is defined in 
5.2.13.4.2. 


SCOPE field 
The SCOPE field indicates the scope to which the RESOURCE COUNT field applies and is defined in table 316. 
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The Total Efficiency LBA Resource Count log parameter of the Logical Block Provisioning log page (see table 322) contains 
information about the combined effects of all LBA resource efficiencies (e.g., the result of the combination of de-duplicated LBA 


resources and compressed LBA resources). 






























































Table 322 ‘Total Efficiency LBA Resource Count log parameter format 

Bit 7 6 5 4 3 0 
Byte 

0 (MSB) 

PARAMETER CODE (0102h) 

1 (LSB) 

2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 

3 PARAMETER LENGTH (08h) 

4 (MSB) 

RESOURCE COUNT 

7 (LSB) 

8 Reserved SCOPE 

9 

Reserved 
11 














PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.1 and shall be as shown in table 322 for the Total Efficiency LBA Resource Count log parame- 


ters. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1 and shall be set as shown in table 322 for the Total Efficiency LBA Resource Count log 
parameters. 


RESOURCE COUNT field 


The RESOURCE COUNT field indicates an estimate of the number of LBA resources made available by the combined effects of all LBA resource 
efficiency methods (e.g., de-duplication and compression) and is defined in 5.2.13.4.2. The algorithm used to calculate this value is not defined 


by this standard. 


SCOPE field 
The SCOPE field indicates the scope to which the RESOURCE COUNT field applies and is defined in table 316. 
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5.2.14 Non-Medium Error log page (06h/00h) 


5.2.14.1 Overview 


The Non-Medium Error log page (page code 06h) provides for counting the occurrences of recoverable error events other than 
write, read, or verify failures. No discrimination among the various types of events is provided by parameter code (see table 323). 
Vendor specific discrimination may be provided through Seagate specific parameter codes. 


Table 323. Non-medium error event parameter codes 








eee Resettable or Support 
Parameter code Description Reference , 
e Changeable !! Required 
0000h Non-medium error count Reset Only 5.2.14 Mandatory 











8000h - FFFFh Vendor specific error counts 











All others Reserved 











[a] The keywords in this column - Always, Reset Only, and Never — are defined in 5.2.2.3. 





The Non-Medium Error log page has the format shown in table 324. 


Table 324 Non-Medium Error log page 























Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (Ob) PAGE CODE (06h) 
1 SUBPAGE CODE (00h) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 
NON-MEDIUM ERROR LOG PARAMETERS 
4 FIRST NON-MEDIUM ERROR COUNT LOG PARAMETER (see table 323) 
n LAST NON-MEDIUM ERROR COUNT LOG PARAMETER (see table 322) 











DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 
The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 5.2.2. 


SPF bit, PAGE CODE field, and SUBPAGE CODE field 
The SPF bit, PAGE CODE field, and SUBPAGE CODE field shall be set as shown in table 324 for the Non-Medium Error log page. 


NON-MEDIUM ERROR LOG PARAMETERS 
The contents of each non-medium error log parameter depends on the value in its PARAMETER CODE field (see table 323). 
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5.2.14.2. Non-Medium Error Count log parameter 


The Non-Medium Error Count log parameter has the format shown in table 325. 


Table 325 Non-Medium Error Count log parameter 





















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE 

1 (LSB) 

2 PARAMETER CONTROL BYTE - bounded data counter log parameter (see 5.2.2.2.2.2) 

3 PARAMETER LENGTH (n - 3) 

4 (MSB) 

NON-MEDIUM ERROR COUNT 

255 (LSB) 








PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.2, and shall be set as shown in table 325 for the Non-Medium Error Count log parameter. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.1. 


NON-MEDIUM ERROR COUNT field 


The NON-MEDIUM ERROR COUNT field indicates the number of recoverable error events other than read, read reverse, verify, or write failures. 
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5.2.15 Pending Defects log page (15h/01h) 


5.2.15.1 Pending Defects log page overview 


Using the format defined in table 198, the Pending Defects log page reports an unsorted list of logical blocks for which the 
device server has detected an unrecovered medium error. The parameter codes for the Pending Defects log page are listed in 
table 326. 


Table 326 Pending Defects log page parameter codes 



































Parameter code Description pana Reference ae d 
0000h Pending Defect count Never 4.2.14.2 Mandatory 
0001h - FOOOh Pending Defect Never 4.2.14.3 Mandatory 
All others Reserved 

[a] The keywords in this column - Always, Reset Only, and Never — are defined in 5.2.2.3. 





The Pending Defects log page has the format shown in table 327. 


Table 327 Pending Defects log page 









































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (1b) PAGE CODE (15h) 
1 SUBPAGE CODE (01h) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 
PENDING DEFECTS PARAMETERS 
4 
PENDING DEFECT PARAMETER [first] (see table 330) 
PENDING DEFECT PARAMETER [last] (see table 330) 
n 
DS bit 


The disable save (DS) bit is described in 5.2.2. 


SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 5.2.2 and shall be set to the values defined in table 
327 for the Pending Defects log page. 


Pending Defect Parameter fields 


The contents of each pending defect parameter depends on the value in its PARAMETER CODE field (see table 330). 
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5.2.15.2 Pending Defect Count log parameter 


The Pending Defect Count log parameter has the format defined in table 328 and indicates the number of Pending Defect log 
parameters that are available. 


Table 328 Pending Defect Count log parameter format 























Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PARAMETER CODE (0000h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (04h) 
4 (MSB) 
PENDING DEFECT COUNT 
n (LSB) 














PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.2 and shall be set as defined in table 328 for the Pending Defect Count log parameter. 


PARAMETER LIST LENGTH field 

The PARAMETER LIST LENGTH field is described in 5.2.2.2.1 and shall be set to the value defined in table 328 for the Pending Defect Count log 
parameter. 

PENDING DEFECT COUNT field 


The PENDING DEFECT COUNT field indicates the number of Pending Defect log parameters that are available. The PENDING DEFECT COUNT 
field changes whenever the number of Pending Defect log parameters (see 5.2.15.3) changes. 
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5.2.15.3 Pending Defect log parameter 


A Pending Defect log parameter has the format defined in table 329. If no unrecovered errors have occurred then no Pending 
Defect log parameters shall be present. A Pending Defect log parameter shall be added for each LBA for which the device server 
has detected an unrecovered medium error that is not: 


a) a pseudo unrecovered read error (see SPC-5); 
b) a predicted unrecovered read error (see SPC-5); or 


c) a predicted unrecovered write error (see SPC-5). 


If all of the supported parameter code values have been used and a new defect is discovered, then the device server shall not 
add more Pending Defect log parameters and the PENDING ERROR COUNT field shall not be changed. 


Pending Defect log parameters may be duplicates of Background Scan parameters in the Background Scan log page (see 5.3.4). 
A Pending Defect log parameter shall be removed if the indicated LBA: 


a) is reassigned without error; 
b) is written without error; or 


c) is read without error. 
A Pending Defect log parameter may be removed if the indicated LBA is unmapped without error. 


A sanitize overwrite operation (see SPC-5) and a format operation (see 3.3.1) shall cause all Pending Defect log parameters to be 
removed. 


Table 329 Pending Defect log parameter format 



























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PARAMETER CODE (0001h to FOOOh) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (14h) 
4 (MSB) 
ACCUMULATED POWER ON HOURS 
n (LSB) 
4 (MSB) 
ee LOGICAL BLOCK ADDRESS 
n (LSB) 











PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.2 and shall be set as defined in table 329 for a Pending Defect log parameter. 


PARAMETER LIST LENGTH field 
The PARAMETER LIST LENGTH field is defined in 5.2.2 and shall be set to the value defined in table 329 for a Pending Defect log parameter. 


ACCUMULATED POWER ON HOURS field 


The ACCUMULATED POWER ON HOURS field indicates the number of hours that the device server has been powered on since manufacturing 
at the time the Pending Defect log parameter was created. A value of FFFF_FFFF_FFFF_FFFFh indicates that the accumulated power on hours 
value is unknown. 


LOGICAL BLOCK ADDRESS field 
The LOGICAL BLOCK ADDRESS field indicates the LBA associated with the unrecovered medium error. 
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5.2.16 Power Condition Transitions log page (1Ah/00h) 


5.2.16.1 Overview 


Using the format shown in table 330, the Power Condition Transitions log page (page code 1Ah) provides a count of the 
occurrences of power condition transition events using the parameter codes listed in table 330. 


Table 330 Power Condition Transitions log page parameter codes 


















































Parameter Me Resettable or Support 
Description [al Reference : 
code Changeable '# requirements 
0001h Accumulated transitions to active Never Mandatory 
0002h Accumulated transitions to idle_a At least one [Pl 
0003h Accumulated transitions to idle_b 
0004h Accumulated transitions to idle_c 
0008h Accumulated transitions to standby_z 
0009h Accumulated transitions to standby_y 
all others Reserved 
[a] The keywords in this column - Always, Reset Only, and Never - are defined in 5.2.2.3. 
[b] If the Power Conditions Transitions log page is supported, at least one of these parameter codes shall be supported. 
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5.2.16.2 Power Condition Transitions log page (1Ah) 


The Power Condition Transitions log page (see table 331) provides a count of the occurrences of power condition transition 
events. A device server that implements the Power Condition Transitions log page shall implement one or more of the defined 
parameters. 


Table 331 Power Condition Transitions log page 






































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (Ob) PAGE CODE (1Ah) 
1 SUBPAGE CODE (00h) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 





POWER CONDITION TRANSITIONS LOG PARAMETERS 








FIRST POWER CONDITION TRANSITIONS LOG PARAMETER (see table 332) 











LAST POWER CONDITION TRANSITIONS LOG PARAMETER (see table 332) 

















DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field 
The DS bit, SPF bit, PAGE CODE field and PAGE LENGTH field are described in 5.2.2. 


The format for all log parameters in the Power Condition Transitions log page is shown in table 332. All log parameters in the 
Power Condition Transitions log page contain a four-byte binary value. 
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Table 332 Power Condition Transitions log parameter format 















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PARAMETER CODE (see table 330) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (04h) 
4 (MSB) 
PARAMETER VALUE 
7 (LSB) 














All Power Condition Transitions log page counters are saturating counters (see table 270). A count is incremented by one for 
each transition (see table 272). The time in the transition at which the count is incremented is vendor specific. 


If a LOG SELECT command attempts to change the value of any log parameter in the Power Condition Transitions log page, the 
command shall be terminated with CHECK CONDITION status, with sense key set to ILLEGAL REQUEST and additional sense code 
set to INVALID FIELD IN PARAMETER LIST. 


PARAMETER LENGTH field 


The PARAMETER LENGTH field shall be set as shown in Table 332 and specifies the length in bytes of the PARAMETER VALUE field that follows. If 
the application client specifies a parameter length that results in the truncation of the PARAMETER VALUE field, the command shall be termi- 
nated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN 
PARAMETER LIST. 


PARAMETER VALUE field 


The PARAMETER VALUE field contains a saturating counter as described in Table 270 for the corresponding parameter code value in the Power 
Condition Transitions log parameter PARAMETER CODE field (see table 330). 


SCSI Commands Reference Manual, Rev. J 353 


www.seagate.com Parameters for direct access devices 


5.2.17 Protocol-Specific Port log page (18h/00h) 


The Protocol-Specific Port log page for SAS defined in Table 333 is used to return information about phy events concerning the 
SAS target device's phy(s). 


A phy is defined as an object in a device that is used to interface to other devices. 


Table 333 _—_— Protocol-Specific Port log page for SAS 






































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (Ob) PAGE CODE (18h) 
1 SUBPAGE CODE (00h) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 





PROTOCOL-SPECIFIC PORT LOG PARAMETER LIST 








PROTOCOL-SPECIFIC PORT LOG PARAMETER (first) (see table 334) 











PROTOCOL-SPECIFIC PORT LOG PARAMETER (last) (see table 334) 
n 














DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field 
The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field are described in 5.2.2. 


The protocol-specific port log parameter list contains a protocol-specific port log parameter for each SCSI port in the SAS target 
device. 


Table 334 defines the format for the Protocol-Specific Port log parameter for SAS. The SAS log parameter is a list parameter (i.e., 
not a data counter) and only has cumulative (i.e., not threshold) values (see SPC-5). 
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Table 334 _Protocol-Specific Port log parameter for SAS 



















































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
; PARAMETER CODE (relative target port identifier) SB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (y-3) 
4 Reserved PROTOCOL IDENTIFIER (6h) 
5 Reserved 
6 GENERATION CODE 
7 NUMBER OF PHYS 
SAS PHY LOG DESCRIPTOR LIST 
8 
SAS PHY LOG DESCRIPTOR (first) (see table 335) 
8+m 
y-m 
SAS PHY LOG DESCRIPTOR (last) (see table 335) 
y 


PARAMETER CODE field 


The PARAMETER CODE field is defined in Clause 5.2.2.2 and contains the relative target port identifier (see SPC-5) of the SAS target port that the 
log parameter describes. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is defined in Clause 5.2.2.2 and shall be set to the value defined in Table 334. 


PROTOCOL IDENTIFIER field 
The PROTOCOL IDENTIFIER field is defined in Clause 5.3.23 and shall be set to the value defined in Table 334. 


GENERATION CODE field 
The GENERATION CODE field is defined in the Phy Control and Discover mode page (Clause 5.3.27). 


NUMBER OF PHYS field 


The NUMBER OF PHYS field contains the number of phys in the SAS target port (not in the entire SAS target device) and indicates the number 
of SAS phy log descriptors in the SAS phy log descriptor list. 


The SAS phy log descriptor list contains SAS phy log descriptors. 
Table 335 defines the SAS phy log descriptor. 
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Table 335 SAS phy log descriptor 
Bit 7 6 5 4 3 2 1 0 
Byte 

0 Reserved 
1 PHY IDENTIFIER 
2 Reserved 
3 SAS PHY LOG DESCRIPTOR LENGTH (m - 3) 
4 Reserved ATTACHED DEVICE TYPE ATTACHED REASON 
5 REASON NEGOTIATED LOGICAL LINK RATE 

ATTACHED ATTACHED ATTACHED 
6 Reserved Sai oP aye Reserved 

INITIATOR INITIATOR INITIATOR 

PORT PORT PORT 

ATTACHED ATTACHED ATTACHED 

7 Reserved SSP STP SMP Reserved 
TARGET PORT | TARGET PORT | TARGET PORT 
8 
SAS ADDRESS 
15 
16 
ATTACHED SAS ADDRESS 
23 
24 ATTACHED PHY IDENTIFIER 
25 
a Reserved 
32 (MSB) 
INVALID DWORD COUNT 
35 (LSB) 
36 (MSB) 
RUNNING DISPARITY ERROR COUNT 
39 (LSB) 
40 (MSB) 
LOSS OF DWORD SYNCHRONIZATION 
43 (LSB) 
44 (MSB) 
PHY RESET PROBLEM 
47 (LSB) 
48 
a6 Reserved 
50 PHY EVENT DESCRIPTOR LENGTH 
51 NUMBER OF PHY EVENT DESCRIPTORS 
PHY EVENT DESCRIPTOR LIST 
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Table 335 SAS phy log descriptor 


















































Bit 7 6 5 4 3 2 1 0 
Byte 
52 
PHY EVENT DESCRIPTOR (first) (see table 339) 
63 
m-11 
PHY EVENT DESCRIPTOR (last) (see table 339) 
M 











PHY IDENTIFIER field 


The PHY IDENTIFIER field specifies the phy identifier of the phy that is to perform or to stop performing a phy test function (i.e., the selected 
phy). If the PHY IDENTIFIER field specifies a phy that does not exist, then the device server shall terminate the SEND DIAGNOSTIC command 
with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER 
LIST. 


SAS PHY LOG DESCRIPTOR LENGTH field 


The SAS PHY LOG DESCRIPTOR LENGTH field indicates the number of bytes that follow in the SAS phy log descriptor and shall be 
set to the value defined in Table 335. A SAS PHY LOG DESCRIPTOR LENGTH field set to 00h indicates that there are 44 additional 
bytes. 


NOTE Logical units compliant with SAS and SAS-1.1 only support a 48 byte SAS phy log descriptor. 


ATTACHED DEVICE TYPE field 
The ATTACHED DEVICE TYPE field indicates the type of device attached to this phy, and is defined in Table 336. 


Table 336 Device type field 





























Code Description 
001b End device 
010b Expander device 
011b Expander device compliant with a previous version of the SAS standard 
All others Reserved 
ATTACHED REASON field 


The ATTACHED REASON field indicates the reason received from the attached device for the link reset sequence and is defined in 
Table 337 
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REASON field 


The REASON field indicates the reason sent by the target device for the last link reset sequence and is defined in Table 337. 


Table 337 Reason field definition 











Code Description 
Oh Unknown reason 
th Power on 





Hard reset (e.g., the port containing this phy received a HARD_RESET primitive during the hard reset 
2h sequence) (see SPL-3 r02, Section 4.4.2), or SMP PHY CONTROL function HARD RESET phy operation (see 
SPL-3 r02, Section 9.4.3.28) 




















3h SMP PHY CONTROL function LINK RESET phy operation, or TRANSMIT SATA PORT SELECTION SIGNAL 
phy operation (see SPL-3 r02, Section 9.4.3.28) 

4h Loss of dword synchronization (see SPL-3 r02, Section 5.13) 

5h After the multiplexing sequence completes, MUX (LOGICAL LINK 0) received in logical link 1 or MUX 
(LOGICAL LINK 1) received in logical link 0 (see SPL-3 r02, Section 5.15) 

6h |_T nexus loss timer expired in the STP target port of an STP/SATA bridge when the phy was attached to 
a SATA device (see SPL-3 r02, Section 4.4.3) 

7h Break Timeout Timer expired (see SPL-3 r02, Section 6.14.8) 

8h Phy test function stopped (see SPL-3 r02, Section 9.4.3.29) 

9h Expander device reduced functionality (see SPL-3 r02, Section 4.5.8) 

Ah to Fh Reserved 





NEGOTIATED LOGICAL LINK RATE field 


The NEGOTIATED LOGICAL LINK RATE field is defined in Table 338 and indicates the logical link rate being used by the phy. For 
physical phys, this is negotiated during the link reset sequence. For virtual phys, this field should be set to the maximum physical 
link rate supported by the expander device. This field may be different from the negotiated physical link rate when multiplexing 
is enabled. 


Table 338 NEGOTIATED LOGICAL LINK RATE field 


























NEGOTIATED PHYSICAL LINK RATE field Multiplexing NEGOTIATED LOGICAL LINK RATE field 
Disable 9h (i.e., 3Gb/s) 
9h (i.e., G2) 
Enable 8h (i.e., 1.5Gb/s) 
Disable Ah (i.e., 6Gb/s) 
Ah (i.e., G3) 
Enable 9h (i.e., 3Gb/s) 
Disable Bh (i.e., 12Gb/s) 
Bh (i.e., G4) 
Enable Ah (i.e., 6Gb/s) 
All others Any Same as the NEGOTIATED LOGICAL LINK RATE field 
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ATTACHED SSP INITIATOR PORT bit 
1 An ATTACHED SSP INITIATOR PORT bit set to one indicates that an SSP initiator port is present in the attached device. 
QO An ATTACHED SSP INITIATOR PORT bit set to zero indicates that an SSP initiator port is not present in the attached device. 


ATTACHED STP INITIATOR PORT bit 

1 An ATTACHED STP INITIATOR PORT bit set to one indicates that an STP initiator port is present in the attached device. 

QO = An ATTACHED STP INITIATOR PORT bit set to zero indicates that an STP initiator port is not present in the attached device. 
ATTACHED SMP INITIATOR PORT bit 

1 An ATTACHED SMP INITIATOR PORT bit set to one indicates that an SMP initiator port is present in the attached device. 

QO = An ATTACHED SMP INITIATOR PORT bit set to zero indicates that an SMP initiator port is not present in the attached device. 
ATTACHED SSP TARGET PORT bit 

1 An ATTACHED SSP TARGET PORT bit set to one indicates that an SSP target port is present in the attached device. 

QO  AnATTACHED SSP TARGET PORT bit set to zero indicates that an SSP target port is not present in the attached device. 
ATTACHED STP TARGET PORT bit 

1 An ATTACHED STP TARGET PORT bit set to one indicates that an STP target port is present in the attached device. 

QO = AnATTACHED STP TARGET PORT bit set to zero indicates that an STP target port is not present in the attached device. 


ATTACHED SMP TARGET PORT bit 
1 An ATTACHED SMP TARGET PORT bit set to one indicates that an SMP target port is present in the attached device. 
QO = AnATTACHED SMP TARGET PORT bit set to zero indicates that an SMP target port is not present in the attached device. 
SAS ADDRESS field 
The SAS ADDRESS field indicates the port identifier (see SPL-3 r02, Section 4.2.9) of the SAS port transmitting the IDENTIFY 


address frame. For expander ports, the SAS ADDRESS field indicates the device name (see SPL-3 r02, Section 4.2.6) of the 
expander device transmitting the IDENTIFY address frame. 


ATTACHED SAS ADDRESS field 

The ATTACHED SAS ADDRESS field contains SAS address of the attached SAS port (see SPL-3 r02, Section 4.2.9). 
ATTACHED PHY IDENTIFIER field 

The ATTACHED PHY IDENTIFIER field contains the phy identifier of the attached SAS phy in the attached SAS device. 
INVALID DWORD COUNT field 


The INVALID DWORD COUNT field indicates the number of invalid dwords (see SPL-3 r02, Section 3.1.99) that have been received 
outside of phy reset sequences (i.e., between when the SP state machine (see SPL-3 r02, Section 5.12) sends a Phy Layer Ready 
(SAS) confirmation or Phy Layer Ready (SATA) confirmation and when it sends a Phy Layer Not Ready confirmation to the link 
layer). The count shall stop at the maximum value. The INVALID DWORD COUNT field is set to a vendor-specific value after power 
on. 


For the INVALID DWORD COUNT field, RUNNING DISPARITY ERROR COUNT field, LOSS OF DWORD SYNCHRONIZATION COUNT 
field, and PHY RESET PROBLEM COUNT field, the phy may maintain any size counter but should maintain a 32-bit counter. If it 
reaches its maximum value, then the counter shall stop and the device server shall set the field to FFFFFFFFh in the SAS phy log 
descriptor. 


RUNNING DISPARITY ERROR COUNT field 


The RUNNING DISPARITY ERROR COUNT field indicates the number of dwords containing running disparity errors (see SPL-3 r02, 
Section 5.3.5) that have been received outside of phy reset sequences. The count shall stop at the maximum value. The RUNNING 
DISPARITY ERROR COUNT field is set to a vendor-specific value after power on. 
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LOSS OF DWORD SYNCHRONIZATION COUNT field 


The LOSS OF DWORD SYNCHRONIZATION COUNT field indicates the number of times the phy has restarted the link reset 
sequence because it lost dword synchronization (see SPL-3 r02, Section 5.13) (i.e., the SP state machine transitioned from 
SP15:SAS_PHY_Ready or SP22:SATA_PHY_Ready to SP0:OOB_COMINIT (see SPL-4). The count shall stop at the maximum value. 
The LOSS OF DWORD SYNCHRONIZATION COUNT field is set to a vendor-specific value after power on. 


PHY RESET PROBLEM COUNT field 


The PHY RESET PROBLEM COUNT field indicates the number of times a phy reset problem (see SPL-3 r02, Section 5.10.4.2.4) 
occurred. The count shall stop at the maximum value. The PHY RESET PROBLEM COUNT field is set to a vendor-specific value 
after power on. 


PHY EVENT DESCRIPTOR LENGTH field 


The PHY EVENT DESCRIPTOR LENGTH field indicates the number of bytes in the phy event descriptor (see SPL-3 r02, Section 
9.4.3.14.4). 


NUMBER OF PHY EVENT DESCRIPTORS field 

The NUMBER OF PHY EVENT DESCRIPTORS field indicates the number of phy event descriptors in the phy event descriptor list. 
Each PHY EVENT DESCRIPTOR follows the format defined for the SMP REPORT PHY EVENT function in (see SPL-3 102, Section 
9.4.3.14.4). 


5.2.17.1 Phy event descriptor 
Table 339 defines the phy event descriptor. 


Table 339 Phy event descriptor 





Bit 7 6 5 4 3 2 1 0 
Byte 


























0 





Reserved 








3 PHY EVENT SOURCE 
4 (MSB) 








PHY EVENT 
7 (LSB) 
8 (MSB) 











PEAK VALUE DETECTOR THRESHOLD 
11 (LSB) 

















PHY EVENT SOURCE field 
The PHY EVENT SOURCE field, defined in SAS-3, indicates the type of phy event being reported in the PHY EVENT field. 


PHY EVENT field 


The PHY EVENT field indicates the value (i.e., the count or peak value detected) of the phy event indicated by the PHY EVENT 
SOURCE field. 


PEAK VALUE DETECTOR THRESHOLD field 


If the phy event source is a peak value detector, then the PEAK VALUE DETECTOR THRESHOLD field indicates the value of the 
peak value detector that causes the expander device to originate a Broadcast (Expander) (see SAS-3). If the phy event source is 
not a peak value detector, then the PEAK VALUE DETECTOR THRESHOLD field is reserved. 
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5.2.18 Self-Test Results log page (10h/00h) 


The Self-Test Results log page (see table 340) provides the results from the 20 most recent self-tests (see 3.46). Results from the 
most recent self-test or the self-test currently in progress shall be reported in the first self-test log parameter; results from the 
second most recent self-test shall be reported in the second self-test log parameter; etc. If fewer than 20 self-tests have occurred, 
the unused self-test log parameter entries shall be zero filled. 


Table 340 Self-Test Results log page 
































Bit 7 6 5 4 3 2 1 0 
Byte 

0 DS SPF (Ob) PAGE CODE (10h) 

1 SUBPAGE CODE (00h) 

2 (MSB) 


—_{ PAGE LENGTH (190h) ST 
3 (LSB) 


SELF-TEST RESULTS LOG PARAMETERS 




















4 
FIRST SELF-TEST RESULTS LOG PARAMETER 
(most recent) 
23 
384 
TWENTIETH SELF-TEST RESULTS LOG PARAMETER 
(least recent) 
403 


DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field and PAGE LENGTH field 
The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field and PAGE LENGTH field are described in 5.2.2. 


Table 341 shows the format of one self-test log parameter. 


Table 341 __—Self-test results log parameter format 





Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 


PARAMETER CODE (0001h TO 0014h) ——— 
1 (LSB) 


PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 


















































3 PARAMETER LENGTH (10h) 
4 SELF-TEST CODE Reserved SELF-TEST RESULTS 
5 SELF-TEST NUMBER 
6 (MSB) 
ACCUMULATED POWER ON HOURS 
7 (LSB) 
8 (MSB) 
ape ADDRESS OF FIRST FAILURE 
15 (LSB) 
16 Reserved SENSE KEY 
17 ADDITIONAL SENSE CODE 
18 ADDITIONAL SENSE CODE QUALIFIER 
19 Vendor specific 
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PARAMETER CODE field 

The PARAMETER CODE field identifies the log parameter being transferred. The PARAMETER CODE field for the results of the most recent 
self-test shall contain 0001h; the PARAMETER CODE field for the results of the second most recent test shall contain 0002h; etc. 

PARAMETER LENGTH field 

The PARAMETER LENGTH field shall contain 10h. 


SELF-TEST CODE field 
The SELF-TEST CODE field contains the value in the SELF-TEST CODE field of the SEND DIAGNOSTIC command that initiated this self-test. 
Table 342 defines the content of the SELF-TEST RESULTS field. 


Table 342 SELF-TEST RESULTS field 





Code Description 





Oh The self-test completed without error. 





The background self-test was aborted by the application client using a SEND DIAGNOSTIC command (see 3.46) with the 


ab SELF-TEST CODE field set to 100b (i.e., abort background self-test). 


The self-test routine was aborted by an application client using a method other than a SEND DIAGNOSTIC command 
2h with the SELF-TEST CODE field set to 100b (e.g., by a task management function, or by issuing an exception command 
as defined in SPC-5). 





3h An unknown error occurred while the device server was processing the self-test and the device server was unable to 
complete the self-test. 


4h The self-test completed with a failure in a test segment, and the test segment that failed is not known. 
5h The first segment of the self-test failed. 


6h The second segment of the self-test failed. 





7h Another segment of the self-test failed and which test is indicated by the contents of the SELF-TEST NUMBER field. 





8h-Eh | Reserved 





Fh The self-test is in progress. 














SELF-TEST NUMBER field 
The SELF-TEST NUMBER field identifies the self-test that failed and consists of either: 
a) The number of the segment that failed during the self-test; or 


b) The number of the test that failed and the number of the segment in which the test was run, using a vendor specific method for placing 
the two values in the one field. 


When the segment in which the failure occurred is not able to be identified or need not be identified, the SELF-TEST NUMBER field shall contain 
00h. 
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ACCUMULATED POWER ON HOURS field 


The ACCUMULATED POWER ON HOURS field contains the total hours for the device server has been powered on since manufacturing at the 
time the self-test is completed. If the test is still in progress, the content of the ACCUMULATED POWER ON HOURS field shall be zero. If the 
power-on hours for the device server at the time the self-test was completed is greater than FFFFh then the content of the ACCUMULATED 
POWER ON HOURS field shall be FFFFh. 


ADDRESS OF FIRST FAILURE field 


The ADDRESS OF FIRST FAILURE field contains information that locates the failure on the media. If the logical unit implements logical blocks, 
the content of the ADDRESS OF FIRST FAILURE field is the first logical block address where a self-test error occurred. This implies nothing about 
the quality of any other logical block on the logical unit, since the testing during which the error occurred may not have been performed in a 
sequential manner. This value shall not change (e.g., as the result of block reassignment). The content of the ADDRESS OF FIRST FAILURE field 
shall be FFFF FFFF FFFF FFFFh if no errors occurred during the self-test or if the error that occurred is not related to an identifiable media 
address. 


SENSE KEY, ADDITIONAL SENSE CODE, and ADDITIONAL SENSE CODE QUALIFIER fields 


The SENSE KEY field, ADDITIONAL SENSE CODE field, and ADDITIONAL SENSE CODE QUALIFIER field may contain a hierarchy of additional infor- 
mation relating to error or exception conditions that occurred during the self-test represented in the same format used by the sense data (see 
3.37). 
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5.2.19 Solid State Media log page (11h/00h) 


5.2.19.1 Overview 


Using the format shown in Table 344, the Solid State media log page (PAGE CODE 11h) reports parameters that are specific to SCSI target 
devices that contain solid state media. The parameter codes for the Solid State Media log page are listed in Table 343. 


Table 343 = Solid State Media log parameters 















































Resettable or 
Parameter code Description [al Support 
Changeable '* requirements 
0001h Percentage Used Endurance Indicator Never Mandatory 
all others Reserved 
[a] The keywords in this column — Always, Reset Only, and Never - are defined in 5.2.2.3. 
The Solid State Media log page has the format shown in Table 344. 
Table 344 Solid State Media log page 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (Ob) PAGE CODE (11h) 
1 SUBPAGE CODE (00h) 
2 (MSB) 
PAGE LENGTH (n - 3) ——— 7a 
3 (LSB) 








SOLID STATE MEDIA LOG PARAMETERS (see table 343) 





4 SOLID STATE MEDIA PARAMETER (first 

















n SOLID STATE MEDIA PARAMETER (last) 





DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field 
The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field are described in 5.2.2. 
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5.2.19.2 Percentage Used Endurance Indicator log parameter 


The Percentage Used Endurance Indicator log parameter has the format shown in Table 345. 


Table 345 Percentage Used Endurance Indicator log parameter format 


















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 (MSB) 

PARAMETER CODE (0001h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
3 PARAMETER LENGTH (04h) 
4 

RESERVED 

6 
7 PERCENTAGE USED ENDURANCE INDICATOR 














PARAMETER CODE field 


The PARAMETER CODE field is described in 5.2.2.2.2 and shall be set to the value shown in table 169 for the Percentage Used Endurance Indica- 
tor log parameter. 


PARAMETER LENGTH field 


The PARAMETER LENGTH field is described in SPC-5 and shall be set to the value shown in table 169 for the Percentage Used Endurance Indica- 
tor log parameter. 


PERCENTAGE USED ENDURANCE INDICATOR field 


The PERCENTAGE USED ENDURANCE INDICATOR field indicates an estimate of the percentage of device life that has been used. The value in 
the field shall be set to zero at the time of manufacture. A value of 100 indicates that the estimated endurance of the device has been con- 
sumed, but may not indicate a device failure (e.g., minimum power-off data retention capability reached for devices using flash technology). 
The value is allowed to exceed 100. Values greater than 254 shall be reported as 255. The device server shall update the value at least once per 
power-on hour. 
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5.2.20 Start-Stop Cycle Counter log page (OEh/00h) 


5.2.20.1 Overview 


Using the format shown in table 347, the Start-Stop Cycle Counter log page (page code OEh) provides information about 
manufacturing dates and cycle counts since date of manufacture using the parameter codes listed in table 346. 


Table 346 Solid State Media log parameters 






































Parameter Description Resettable or 
ele Changeable !! 
0001h Date of Manufacture Never 

0002h Accounting Date Always 

0003h Specified Cycle Count Over Device Lifetime Never 

0004h Accumulated Start-Stop Cycles Never 

0005h Specified Load-Unload Count Over Device Lifetime Never 

0006h Accumulated Load-Unload Cycles Never 

all others Reserved 

[a] The keywords in this column - Always, Reset Only, and Never - are defined in 5.2.2.3. 





The Start-Stop Cycle Counter log page has the format shown in table 347. 


Table 347 = Start-Stop Cycle Counter log page (Sheet 1 of 2) 


































































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 DS SPF (0b) PAGE CODE (0Eh) 

1 SUBPAGE CODE(00h) 

2 (MSB) 

PAGE LENGTH (n-3) 

3 (LSB) 
4 (MSB) PARAMETER CODE 0001h 

5 DATE OF MANUFACTURE (LSB) 
6 PARAMETER CONTROL BYTE - ASCII format list log parameter (see 5.2.2.2.2.4) 

7 PARAMETER LENGTH (06h) 

8 (MSB) 
eee YEAR OF MANUFACTURE (4 ASCII CHARACTERS) 
11 (LSB) 
12 (MSB) 

WEEK OF MANUFACTURE (2 ASCII CHARACTERS) J 
13 (LSB) 
14 (MSB) PARAMETER CODE 0002h 
15 ACCOUNTING DATE (LSB) 
16 PARAMETER CONTROL BYTE - ASCII format list log parameter (see 5.2.2.2.2.4) 
17 PARAMETER LENGTH (06h) 
18 (MSB) 
aes ACCOUNTING DATE YEAR (4 ASCII CHARACTERS) 
21 (LSB) 
22 (MSB) 
ACCOUNTING DATE WEEK (2 ASCII CHARACTERS) J 

23 (LSB) 
24 (MSB) PARAMETER CODE 0003h 
25 SPECIFIED CYCLE COUNT OVER DEVICE LIFETIME (LSB) 
26 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
27 PARAMETER LENGTH (04h) 
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Table 347 = Start-Stop Cycle Counter log page (Sheet 2 of 2) 







































































Bit 7 6 5 4 3 2 1 0 
Byte 
28 (MSB) 
SPECIFIED CYCLE COUNT OVER DEVICE LIFETIME 
— (4-BYTE BINARY NUMBER) —___ 
31 (LSB) 
32 (MSB) PARAMETER CODE 0004h 
33 ACCUMULATED START-STOP CYCLES (LSB) 
34 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
35 PARAMETER LENGTH (04h) 
36 (MSB) 
ACCUMULATED START-STOP CYCLES 
— (4-BYTE BINARY NUMBER) ——__—_ 
39 (LSB) 
40 (MSB) PARAMETER CODE 0005h 
41 SPECIFIED LOAD-UNLOAD COUNT OVER DEVICE LIFETIME (LSB) 
42 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
43 PARAMETER LENGTH (04h) 
44 (MSB) 





SPECIFIED LOAD-UNLOAD COUNT OVER DEVICE LIFETIME 


tee (4-BYTE BINARY NUMBER) ep, | 
a (LSB) 




















48 (MSB) PARAMETER CODE 0006h 

49 ACCUMULATED LOAD-UNLOAD CYCLES (LSB) 
50 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 

51 PARAMETER LENGTH (04h) 

52 (MSB) 





ACCUMULATED LOAD-UNLOAD CYCLES 


tee (4-BYTE BINARY NUMBER) ep), | 
= (LSB) 

















The year and week in the year that the SCSI target device was manufactured shall be contained in the parameter value of the log 
parameter in which the parameter code is 0001h. The date of manufacture shall not be saveable by the application client using 
the LOG SELECT command (i.e., the log parameter DS bit shall be set to one). The date is expressed in numeric ASCII characters 
(30h — 39h) in the form YYYYWW, as shown in table 347. 


The accounting date specified by parameter code 0002h may be saved using a LOG SELECT command to indicate when the 
device was placed in service. If the parameter is not yet set or is not settable, the default value placed in the parameter field shall 
be 6 ASCII space characters (20h). The field shall not be checked for validity by the device server. 


The parameter value in the specified cycle count over device lifetime log parameter (parameter code 0003h) shall contain a 
four-byte binary value that indicates how many stop-start cycles may typically be performed over the lifetime of the SCSI target 
device without degrading the SCSI target device's operation or reliability outside the limits specified by the manufacturer of the 
SCSI target device. The specified cycle count over device lifetime parameter shall not be saveable by the application client using 
the LOG SELECT command (i.e., the log parameter DS bit shall be set to one). 
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The parameter value in the accumulated start-stop cycles log parameter (parameter code 0004h) shall contain a four-byte binary 
value that indicates how many stop-start cycles the SCSI target device has detected since its date of manufacture. The 
accumulated start-stop cycles parameter shall not be saveable by the application client using the LOG SELECT command (i.e., 
the log parameter DS bit shall be set to one). The time at which the count is incremented during a start-stop cycle is vendor 
specific. For rotating magnetic storage devices, a single start-stop cycle is defined as an operational cycle that begins with the 
disk spindle at rest, continues while the disk accelerates to its normal operational rotational rate, continues during the entire 
period the disk is rotating, continues as the disk decelerates toward a resting state, and ends when the disk is no longer rotating. 
For devices without a spindle or with multiple spindles, the definition of a single start-stop cycle is vendor specific. The count is 
incremented by one for each complete start-stop cycle. No comparison with the value of parameter 0003h shall be performed 
by the device server. 


The parameter value in the specified load-unload count over device lifetime log parameter (parameter code 0005h) shall contain 
a four-byte binary value that indicates how many load-unload cycles may be performed over the lifetime of the SCSI target 
device without degrading the SCSI target device's operation or reliability outside the limits specified by the manufacturer of the 
SCSI target device. The specified load-unload count parameter shall not be saveable by the application client using the LOG 
SELECT command (i.e., the log parameter DS bit shall be set to one). The time at which the count is incremented during a 
specified load-unload count is vendor specific. For rotating magnetic storage devices, a single load-unload cycle is defined as an 
operational cycle that begins with the disk spindle at rest, continues while the disk accelerates to its normal operational 
rotational rate, continues during the entire period the disk is rotating, continues as the disk decelerates toward a resting state, 
and ends when the disk is no longer rotating. For devices without a spindle or with multiple spindles, the definition of a single 
load-unload cycle is vendor specific. The count is incremented by one for each complete load-unload cycle. No comparison with 
the value of parameter 0005h shall be performed by the device server. 


The parameter value in the accumulated load-unload count over device lifetime log parameter (parameter code 0006h) shall 
contain a four-byte binary value that indicates the SCSI target device has detected since its date of manufacture. This saturating 
counter is incremented by one for each complete cycle. The time in the cycle at which the counter is incremented is vendor 
specific. 


For rotating magnetic storage devices (see SBC-4), a single load-unload cycle is defined as an operational cycle that: 
a) begins with the heads unloaded from the medium; 

b) continues while the heads are loaded onto the spinning medium; and 

c) ends when the heads are unloaded from the medium. 


The Accumulated Load-Unload Cycles log parameter is not applicable to rotating magnetic storage devices without unloadable 
heads. 


The device server shall not compare the contents of the ACCUMULATED LOAD-UNLOAD CYCLES field to contents of the 
SPECIFIED LOAD-UNLOAD COUNT OVER DEVICE LIFETIME field. 


DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field 
The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE and PAGE LENGTH field are described in 5.2.2. 
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5.2.21 Supported Log Pages log page (00h/00h) 


The Supported Log Pages log page (see table 348) returns the list of log pages implemented by the logical unit. Logical units 
that implement the LOG SENSE command shall implement this log page. 


Table 348 Supported log pages 















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF(1b) PAGE CODE (00h) 
1 SUBPAGE CODE (00h) 
2 (MSB) 
PAGE LENGTH (N-3) 

3 (LSB) 
4 

SUPPORTED PAGE LIST 
n 














This log page is not defined for the LOG SELECT command. This log page returns the list of supported log pages for the specified 
logical unit. 


DS bit, SPF bit, PAGE CODE field and SUBPAGE CODE field 
The DS bit, SPF bit, PAGE CODE field and SUBPAGE CODE field are described in 5.2.2. 


PAGE LENGTH field 
The PAGE LENGTH field indicates the length in bytes of the following supported log page list. 


SUPPORTED PAGE LIST field 


The SUPPORTED PAGE / SUBPAGE LIST field shall contain a list of all log page codes implemented by the logical unit in ascending order begin- 
ning with page code 00h. Each supported log page is indicated in a one byte entry. 
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5.2.22 Supported Log Pages and Subpages log page (00h/FFh) 


For the LOG SENSE command, the Supported Log Pages and Subpages log page (see table 349) returns the list of log pages and subpages 
implemented by the logical unit. If log subpages are supported this page shall be supported. This log page is not defined for the LOG SELECT 
command. 


Table 349 Supported Log Pages and Subpages log page (00h/ FFh) 






























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (1b) PAGE CODE (00h) 
1 SUBPAGE CODE (FFh) 
2 (MSB) 
PAGE LENGTH (n - 3) 
3 (LSB) 
SUPPORTED PAGE/SUBPAGE DESCRIPTORS 
4 
5 FIRST SUPPORTED PAGE/SUBPAGE DESCRIPTOR (see table 350) 
n-1 
LAST SUPPORTED PAGE/SUBPAGE DESCRIPTOR (see table 350) 
n 








DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 5.2.2. The DS bit, SPF bit, PAGE CODE field, 
and SUBPAGE CODE field shall be set as shown in table 350 for the Supported Log Pages and Subpages log page. 


The supported page/subpage descriptors (see table 350) shall be in ascending order sorted by page code then subpage code and shall include 
a descriptor with subpage code 00h for any implemented log page in which the SPF bit is set to zero. 


Table 350 Supported page/subpage descriptor 
































Bit 7 6 5 4 3 

Byte 
0 Reserved PAGE CODE 
1 SUBPAGE CODE 














PAGE CODE field 
The PAGE CODE field indicates the number of a supported log page. 


SUBPAGE CODE field 
The SUBPAGE CODE field indicates the subpage number of a supported log page. 
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5.2.23 Temperature log page (ODh/00h) 


5.2.23.1 Overview 


The Temperature log page provides information about the current operating temperature of the SCSI Target Device using the 
parameter codes listed in table 351. 


Table 351 Temperature log page parameter codes 





























Parameter code Description Resettable or Changeable !#! Support Required 
0000h Temperature Never Mandatory 
0001h Reference Temperature Never Optional 
All others Reserved 
[a] The keywords in this column - Always, Reset Only, and Never - are defined in 5.2.2.3. 








The Temperature log page has the format shown in table 352. 


Table 352 Temperature log page 









































Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS SPF (0) PAGE CODE (0Dh) 
1 SUBPAGE CODE (00h) 
2 (MSB) 
PAGE LENGTH (0Ch) 

3 (LSB) 
4 (MSB) 

PARAMETER CODE 0000h) 
5 (LSB) 
6 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
7 PARAMETER LENGTH (02h) 
8 Reserved 
9 TEMPERATURE 
10 (MSB) 

PARAMETER CODE 0001h) J 
11 (LSB) 
12 PARAMETER CONTROL BYTE - binary format list log parameter (see 5.2.2.2.2.5) 
13 PARAMETER LENGTH (02h) 
14 Reserved 
15 REFERENCE TEMPERATURE 














DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 5.2.2. The SPF bit, PAGE CODE field, and SUB- 
PAGE CODE field shall be set as shown in table 352 for the Temperature log page. 
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PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.2, and shall be set as shown in table 352 for the Temperature log parameter. 


PARAMETER LENGTH field 
The PARAMETER LENGTH field is described in 5.2.2.2.2, and shall be set as shown in table 352 for the Temperature log parameter. 


TEMPERATURE field 


The TEMPERATURE field indicates the temperature of the SCSI target device in degrees Celsius at the time the LOG SENSE command is per- 
formed. Temperatures equal to or less than zero degrees Celsius shall cause the TEMPERATURE field to be set to zero. If the device server is 
unable to detect a valid temperature because of a sensor failure or other condition, then the TEMPERATURE field shall be set to FFh. The tem- 
perature should be reported with an accuracy of plus or minus three Celsius degrees while the SCSI target device is operating at a steady state 
within its environmental limits. 


No comparison is performed between the contents of the TEMPERATURE field and the contents of the optional REFERENCE TEMPERATURE 
field. 


REFERENCE TEMPERATURE field 


The REFERENCE TEMPERATURE field indicates the maximum reported sensor temperature in degrees Celsius at which the SCSI target device is 
capable of operating continuously without degrading the SCSI target device's operation or reliability beyond manufacturer accepted limits. If 
the device server is unable to return a reference temperature and the optional Reference Temperature log parameter is included in the Tem- 
perature log page being returned, then REFERENCE TEMPERATURE field is set to FFh. 


The reference temperature may change for vendor specific reasons. 
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5.2.24 Utilization log page (OEh/01h) 


5.2.24.1 Utilization log page overview 


Using the format shown intable 359, the Utilization log page reports estimates of the rate at which device wear factors (e.g., 
damage to the recording medium) are being used. The parameter codes for the Utilization log page are defined in table 353. 


Table 353 ~—_ Utilization log page parameter codes 





























Parameter code Description peeerre Reference aaa 
0000h Workload Utilization Never 5.2.24.2 Mandatory 
0001h Utilization Usage Rate Based on Date and Time Never 5.2.24.3 Optional 

All others Reserved 
[a] The keywords in this column - Always, Reset Only, and Never - are defined in 5.2.2.3. 











The Utilization log page has the format defined in table 359. 


Table 354 Utilization log page 





























Bit 7 6 5 4 3 2 1 0 
Byte 
0 DS (1b) SPF (1b) PAGE CODE (0Eh) 
1 SUBPAGE CODE (01h) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 
UTILIZATION LOG PARAMETERS 

4 

Utilization log parameter [first] (see table 353) 

Utilization log parameter [last] (see table 353) 
n 














DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The DS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 5.2.2 and shall be set to the values shown in 
table 354 for the Utilization log page. 
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5.2.24.2 Workload Utilization log parameter 
The Workload Utilization log parameter for the Utilization log page has the format defined in table 355. 


Table 355 Workload Utilization log parameter format 





















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PARAMETER CODE (0000h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - bounded data counter log parameter (see 5.2.2.2.2.2) 
3 PARAMETER LENGTH (02h) 
4 (MSB) 
WORKLOAD UTILIZATION 
5 (LSB) 





PARAMETER CODE field 
The PARAMETER CODE field is described in 5.2.2.2.2 and shall be set to the value shown in table 355 for the Workload Utilization log parameter. 


PARAMETER LENGTH field 

The PARAMETER LENGTH field is described in 5.2.2.2.2 and shall be set to the value shown in table 355 for the Workload Utilization log parame- 
ter. 

WORKLOAD UTILIZATION field 


The WORKLOAD UTILIZATION field (see table 356) contains an estimate of the utilization associated with the logical unit as a percentage of the 
manufacturer's designs for various wear factors (e.g., wear of the medium, head load events), if any. The the units for the reported values are 
percent times 100 and range from 0.00% to 655.35%. 


Table 356 WORKLOAD UTILIZATION field 











Code Description 
0 to 9999 Less than (i.e., 0.00% to 99.99% of) the designed workload has been utilized. 
10000 Exactly the designed workload for the device has been utilized. 





10001 to 65534 Greater than (i.e., 100.01% to 655.34% of) the designed workload has been utilized. 














65535 Greater than 655.34% of the designed workload has been utilized. 
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5.2.24.3 Utilization Usage Rate Based on Date and Time 


The Utilization Rate Based on Date and Time log parameter for the Utilization log page has the format defined in table208. If the 
current date and time has not been initialized by a SET TIMESTAMP command (see SPC-5), then the Utilization Rate Based on Date 
and Time log parameter shall not be returned in the Utilization log page (see table 355). 


Table 357 Utilization Rate Based on Date and Time log parameter format 












































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
PARAMETER CODE (0001h) 
1 (LSB) 
2 PARAMETER CONTROL BYTE - bounded data counter log parameter (see 5.2.2.2.2.2) 
3 PARAMETER LENGTH (02h) 
4 DATE AND TIME BASED UTILIZATION RATE 
5 Reserved 














PARAMETER CODE field 

The PARAMETER CODE field is described in 5.2.2.2.2 and shall be set to the value shown in table 357 for the Utilization Rate Based on Date and 
Time log parameter. 

PARAMETER LENGTH field 

The PARAMETER LENGTH field is described in 5.2.2.2.2 and shall be set to the value shown in table 357 for the Utilization Rate Based on Date 
and Time log parameter. 

DATE AND TIME BASED UTILIZATION RATE field 


The DATE AND TIME BASED UTILIZATION RATE field (see table 359) contains an estimate of the rate at which device wear factors (e.g., damage 
to the recording medium) associated with the logical unit have been used during the interval that begins at the date and time of manufacture 
and ends at the timestamp that is reported by a REPORT TIMESTAMP command (i.e., the current value of a device clock) (see SPC-5). 


Table 358 DATE ANDTIME BASED UTILIZATION RATE field 





Code Description 





The Workload Utilization usage rate has been less than (i.e., 0% to 99% of) the designed usage rate 
0to99 : ; : ; ; 
during the interval that begins at the date and time of manufacture and ends at the timestamp. 





The Workload Utilization usage rate has been the exact designed usage rate during the interval 








108 that begins at the date and time of manufacture and ends at the timestamp. 
The Workload Utilization usage rate has been greater than (i.e., 101% to 254% of) the designed 
101 to 254 usage rate during the interval that begins at the date and time of manufacture and ends at the 
timestamp. 
255 The Workload Utilization usage rate has been greater than 254% of designed usage rate during the 











interval that begins at the date and time of manufacture and ends at the timestamp. 
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5.3 Mode parameters 


5.3.1 Mode parameters overview 


Parameters for direct access devices 


This subclause describes the mode parameter headers, block descriptors, and mode pages used with MODE SELECT command 
(see 3.9 and 3.10) and MODE SENSE command (see 3.11 and 3.12) that are applicable to all SCSI devices. Subpages are identical 
to mode pages except that they include a SUBPAGE CODE field that further differentiates the mode page contents. Mode pages 
specific to each device type are described in the command standard that applies to that device type. 


NOTE Many ofthe mode parameters in the following pages are changeable. A MODE SENSE command with 
the PC bit set to one will return a mask indicating the mode parameters that may be changed by a 
SCSI initiator port. Seagate disk drive product manuals indicate which pages a drive supports, what 


the default mode values are, and what mode parameters may be changed. 


Table 359 defines the mode pages that are applicable to all device types that implement the MODE SELECT and MODE SENSE 


commands. 


Table 359 Mode page codes and subpage codes 



































Page code Subpage code Mode Page Name Reference 
OAh 02h Application Tag 5.3.6 
1Ch Oth Background Control 5.3.7 
OAh 06h Background Operation Control 5.3.8 
08h 00h Caching 5.3.9 
OAh 03h Command Duration Limit A 5.3.10 
OAh 04h Command Duration Limit B 5.3.11 
OAh 00h Control 5.3.12 
OAh O1h Control Extension 5.3.13 
02h 00h Disconnect-Reconnect for FC 5.3.14 
02h 00h Disconnect-Reconnect for SAS 5.3.15 
03h 00h Format Device mode page (Obsolete) 5.3.16 
OAh 05h IO Advice Hints Grouping 5.3.17 
1Ch 00h Informational Exceptions Control 5.3.18 
1Ch 02h Logical Block Provisioning 5.3.19 
1Ah 00h Power Condition 5.3.20 
1Ah O1h Power Consumption 5.3.21 
Oth 00h Read-Write Recovery 5.3.22 
18h 00h Logical Unit Control (FC) 5.3.23 
18h 00h Logical Unit Control (SAS) 5.3.24 
19h 00h Protocol Specific Port (FC) 5.3.25 
19h 00h Protocol Specific Port (SAS) 5.3.26 
19h O1h Phy Control and Discover 5.3.27 

[a] Valid only for the MODE SENSE command 








SCSI Commands Reference Manual, Rev. J 


376 


www.seagate.com Parameters for direct access devices 


Table 359 Mode page codes and subpage codes 






























































Page code Subpage code Mode Page Name Reference 
19h 02h Share Port Control 5.3.28 
19h 03h Enhanced Phy Control 5.3.29 
19h E5h Transceiver Control (Out) - SAS 5.3.30 
19h E6h Transceiver Control (In) - SAS 5.3.31 
04h 00h Rigid Drive Geometry Parameters page (Obsolete) 5.3.32 
00h not applicable Seagate specific Unit Attention parameters for HDD 5.3.33 
00h not applicable Seagate specific Unit Attention parameters for SSD 5.3.34 
07h 00h Verify Recovery 5.3.35 
09h 00h Obsolete 
0Ch 00h Obsolete 

00h - 3Eh FFh Return all subpages for the specified page code [a] 
3Fh 00h Return all pages not including subpages [a] 
3Fh FFh Return all pages and subpages [a] 

[a] Valid only for the MODE SENSE command 
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5.3.2 Mode parameter list format 


The mode parameter list shown in table 360 contains a header, followed by zero or more block descriptors, followed by zero or 
more variable-length mode pages. Parameter lists are defined for each device type. 


Table 360 Mode parameter list 





Bit 7 6 5 4 3 2 1 0 
Byte 


























MODE PARAMETER HEADER 
BLOCK DESCRIPTOR(S) 
MODE PAGE(S) OR VENDOR SPECIFIC (E.G., PAGE CODE SET TO ZERO) 




















5.3.3 Mode parameter header formats 


The mode parameter header that is used by the MODE SELECT(6) command (see 3.9) and the MODE SENSE(6) command (see 
3.11) is defined in table 361. 


Table 361 Mode parameter header(6) 












































Bit 7 6 5 4 3 2 1 0 
Byte 

0 MODE DATA LENGTH 

1 MEDIUM TYPE 

2 WP Reserved DPOFUA Reserved 

3 BLOCK DESCRIPTOR LENGTH 














The mode parameter header that is used by the MODE SELECT(10) command (see 3.10) and the MODE SENSE(10) command (see 
3.12) is defined in table 362. 


Table 362 Mode parameter header(10) 















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
MODE DATA LENGTH 
1 (LSB) 
2 MEDIUM TYPE 
3 WP Reserved DPOFUA Reserved 
4 Reserved LONGLBA 
5 Reserved 
6 (MSB) 
BLOCK DESCRIPTOR LENGTH 
7 (LSB) 
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MODE DATA LENGTH field 

When using the MODE SENSE command, the MODE DATA LENGTH field indicates the length in bytes of the following data that is available to be 
transferred. The mode data length does not include the number of bytes in the MODE DATA LENGTH field. When using the MODE SELECT com- 
mand, this field is reserved. 

MEDIUM TYPE field 


The contents of the MEDIUM TYPE field are unique for each device type. Refer to the mode parameters subclause of the specific device type 
command standard for definition of these values. Some device types reserve this field. 


WP (Write Protect) bit 


1 AWP bit set to one indicates that the medium is write-protected. The medium may be write protected when the software write protect 
(SWP) bit in the Control mode page (see 5.3.12) is set to one or if another vendor specific mechanism causes the medium to be write pro- 
tected. 


0 AWP bit set to zero indicates that the medium is not write-protected. 


DPOFUA (DPO and FUA support) bit 
0 A DPOFUA bit set to zero indicates that the device server does not support the DPO and FUA bits. 
1 When used with the MODE SENSE command, a DPOFUA bit set to one indicates that the device server supports the DPO and FUA bits 
(see 3.16) 
LONGLBA (Long LBA) bit 
0 If the Long LBA (LONGLBA) bit is set to zero, the mode parameter block descriptor(s), if any, are each eight bytes long. 


1 If the LONGLBA bit is set to one, the mode parameter block descriptor(s), if any, are each sixteen bytes long. 


BLOCK DESCRIPTOR LENGTH field 


The BLOCK DESCRIPTOR LENGTH field contains the length in bytes of all the block descriptors. It is equal to the number of block descriptors 
times eight if the LONGLBA bit is set to zero or times sixteen if the LONGLBA bit is set to one, and does not include mode pages or vendor spe- 
cific parameters (e.g., page code set to zero), if any, that may follow the last block descriptor. A block descriptor length of zero indicates that no 
block descriptors are included in the mode parameter list. This condition shall not be considered an error. 
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5.3.4 Mode parameter block descriptors 


5.3.4.1 Mode block descriptors overview 


If the device server returns a mode parameter block descriptor, it shall return a short LBA mode parameter block descriptor (see 
5.3.4.2) in the mode parameter data in response to: 


a) a MODE SENSE (6) commana; or 
b) a MODE SENSE (10) command with the LLBAA bit set to zero. 


If the device server returns a mode parameter block descriptor and the number of logical blocks is greater than FFFFFFFFh, it 
may return a long LBA mode parameter block descriptor (see 5.3.4.3) in the mode parameter data in response to a MODE SENSE 
(10) command with the LLBAA bit set to one. 


If the application client sends a mode parameter block descriptor in the mode parameter list, it shall send a short LBA mode 
parameter block descriptor (see 5.3.4.2) for a MODE SELECT (6) command. 


If the application client sends a mode parameter block descriptor in the mode parameter list, it may send a long LBA mode 
parameter block descriptor (see 5.3.4.3) for a MODE SELECT (10) command. 


Support for the mode parameter block descriptors is optional. The device server shall establish a unit attention condition with 
the additional sense code of MODE PARAMETERS CHANGED (see SPC-5 and SAM-5) when the block descriptor values are 
changed. 


5.3.4.2 Short LBA mode parameter block descriptor 
Table 363 defines the block descriptor for direct-access block devices used: 


a) with the MODE SELECT (6) and MODE SENSE (6) commands, and 
b) with the MODE SELECT (10) and MODE SENSE (10) commands when the LONGLBA bit is set to zero in the mode parameter 











header (see 5.3.3). 
Table 363 Short LBA mode parameter block descriptor 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
NUMBER OF BLOCKS 
3 (LSB) 
4 Reserved 
5 (MSB) 
LOGICAL BLOCK LENGTH 
7 (LSB) 














A device server shall respond to a MODE SENSE command (see 3.12) by reporting the number of logical blocks specified in the 
NUMBER OF LOGICAL BLOCKS field sent in the last MODE SELECT command that contained a mode parameter block descriptor. 
If no MODE SELECT command with a mode parameter block descriptor has been received then the current number of logical 
blocks shall be returned. To determine the number of logical blocks at which the logical unit is currently formatted, the 
application client shall use the READ CAPACITY command (see 3.20) rather than the MODE SENSE command. 


On a MODE SENSE command, the device server may return a value of zero indicating that it does not report the number of 
logical blocks in the short LBA mode parameter block descriptor. 


On a MODE SENSE command, if the number of logical blocks on the medium exceeds the maximum value that is able to be 
specified in the NUMBER OF LOGICAL BLOCKS field, the device server shall return a value of FFFFFFFh. 
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If the logical unit does not support changing its capacity by changing the NUMBER OF LOGICAL BLOCKS field using the MODE 
SELECT command (see 3.9 and 3.10), the value in the NUMBER OF LOGICAL BLOCKS field is ignored. 


If the device supports changing its capacity by changing the NUMBER OF LOGICAL BLOCKS field, then the NUMBER OF LOGICAL 
BLOCKS field is interpreted as follows: 


a) _ If the NUMBER OF LOGICAL BLOCKS field is set to zero, the logical unit shall retain its current capacity if the logical block length has not 
changed. If the NUMBER OF LOGICAL BLOCKS field is set to zero and the content of the LOGICAL BLOCK LENGTH field (i.e., new logical 
block length) is different than the current logical block length, the logical unit shall be set to its maximum capacity when the new logical 
block length takes effect (i.e., after a successful FORMAT UNIT command); 

b) If the NUMBER OF LOGICAL BLOCKS field is greater than zero and less than or equal to its maximum capacity, the logical 
unit shall be set to that number of logical blocks. If the content of the LOGICAL BLOCK LENGTH field is the same as the cur- 
rent logical block length, the logical unit shall not become format corrupt. This capacity setting shall be retained through 
power cycles, hard resets, logical unit resets, and |_T nexus losses. If the content of the LOGICAL BLOCK LENGTH field is the 
same as the current logical block length this capacity setting shall take effect on successful completion of the MODE 
SELECT command. If the content of the LOGICAL BLOCK LENGTH field (i.e., new logical block length) is different than the 
current logical block length this capacity setting shall take effect when the new logical block length takes effect (i.e., after 
a successful FORMAT UNIT command); 


c) If the NUMBER OF LOGICAL BLOCKS field is set to a value greater than the maximum capacity of the device and less than 
FFFFFFFFh, then the MODE SELECT command shall be terminated with CHECK CONDITION status with the sense key set to 
ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. The logical unit shall retain its 
previous logical block descriptor settings; or 


d) If the NUMBER OF LOGICAL BLOCKS field is set to FFFFFFFFh, the logical unit shall be set to its maximum capacity. If the 
content of the LOGICAL BLOCK LENGTH field is the same as the current logical block length, the logical unit shall not 
become format corrupt. This capacity setting shall be retained through power cycles, hard resets, logical unit resets, and 
|_T nexus losses. If the content of the LOGICAL BLOCK LENGTH field is the same as the current logical block length this 
capacity setting shall take effect of successful completion of the MODE SELECT command. If the content of the LOGICAL 
BLOCK LENGTH field (i.e., new logical block length) is different than the current logical block length this capacity setting 
shall take effect when the new logical block length takes effect (i.e., after a successful FORMAT UNIT command). 


LOGICAL BLOCK LENGTH field 


The LOGICAL BLOCK LENGTH field specifies the length in bytes of each logical block. No change shall be made to any logical blocks on the 
medium until a format operation is initiated by an application client. 


A device server shall respond to a MODE SENSE command (see 3.11 and 3.12) by reporting the length of the logical blocks as 
specified in the LOGICAL BLOCK LENGTH field sent in the last MODE SELECT command that contained a mode parameter block 
descriptor. If no MODE SELECT command with a block descriptor has been received then the current logical block length shall be 
returned (e.g., if the logical block length is 512 bytes and a MODE SELECT command occurs with the LOGICAL BLOCK LENGTH 
field set to 520 bytes, any MODE SENSE commands would return 520 in the LOGICAL BLOCK LENGTH field). To determine the 
logical block length at which the logical unit is currently formatted, the application client shall use the READ CAPACITY 
command rather than the MODE SELECT command. 
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5.3.4.3 Long LBA mode parameter block descriptor 


Table 364 defines the block descriptor for direct-access block devices used with the MODE SELECT (10) command and MODE 
SENSE (10) command when the LONGLBA bit is set to one in the mode parameter header (see 5.3.3). 


Table 364 Long LBA mode parameter block descriptor 


























Bit 7 6 5 4 3 2 1 0 
Byte 
0 (MSB) 
NUMBER OF LOGICAL BLOCKS 

(LSB) 

a Reserved 

11 

12 (MSB) 

LOGICAL BLOCK LENGTH 
15 (LSB) 














A device server shall respond to a MODE SENSE command (see 3.11 and 3.12) by reporting the number of logical blocks specified 
in the NUMBER OF LOGICAL BLOCKS field sent in the last MODE SELECT command that contained a mode parameter block 
descriptor. If no MODE SELECT command with a mode parameter block descriptor has been received then the current number of 
logical blocks shall be returned. To determine the number of logical blocks at which the logical unit is currently formatted, the 
application client shall use the READ CAPACITY command rather than the MODE SENSE command. 


On a MODE SENSE command, the device server may return a value of zero indicating that it does not report the number of 
logical blocks in the long LBA mode parameter block descriptor. 


If the logical unit does not support changing its capacity by changing the NUMBER OF LOGICAL BLOCKS field using the MODE 
SELECT command (see 3.10), the value in the NUMBER OF LOGICAL BLOCKS field is ignored. If the device supports changing its 
capacity by changing the NUMBER OF LOGICAL BLOCKS field, then the NUMBER OF LOGICAL BLOCKS field is interpreted as 
follows: 
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If the NUMBER OF LOGICAL BLOCKS field is set to zero, the logical unit shall retain its current capacity if the logical block length has not 
changed. If the NUMBER OF LOGICAL BLOCKS field is set to zero and the content of the LOGICAL BLOCK LENGTH field (i.e., new logical 
block length) is different than the current logical block length, the logical unit shall be set to its maximum capacity when the new logical 
block length takes effect (i.e., after a successful FORMAT UNIT command). 

If the NUMBER OF LOGICAL BLOCKS field is greater than zero and less than or equal to its maximum capacity, the logical 
unit shall be set to that number of logical blocks. If the content of the LOGICAL BLOCK LENGTH field is the same as the cur- 
rent logical block length, the logical unit shall not become format corrupt. This capacity setting shall be retained through 
power cycles, hard resets, logical unit resets, and |_T nexus losses. If the content of the LOGICAL BLOCK LENGTH field is the 
same as the current logical block length this capacity setting shall take effect on successful completion of the MODE 
SELECT command. If the content of the LOGICAL BLOCK LENGTH field (i.e., new logical block length) is different than the 
current logical block length, this capacity setting shall take effect when the new logical block length takes effect (i.e., after 
a successful FORMAT UNIT command); 


If the NUMBER OF LOGICAL BLOCKS field is set to a value greater than the maximum capacity of the device and less than 
FFFFFFFF FFFFFFFFh, then the device server shall terminate the MODE SELECT command with CHECK CONDITION status 
with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. The 
logical unit shall retain its previous block descriptor settings; or 


If the NUMBER OF LOGICAL BLOCKS field is set to FFFFFFFF FFFFFFFFh, the logical unit shall be set to its maximum capac- 
ity. If the content of the LOGICAL BLOCK LENGTH field is the same as the current logical block length, the logical unit shall 
not become format corrupt. This capacity setting shall be retained through power cycles, hard resets, logical unit resets, 
and I_T nexus losses. If the content of the LOGICAL BLOCK LENGTH field is the same as the current logical block length this 
capacity setting shall take effect on successful completion of the MODE SELECT command. If the content of the LOGICAL 
BLOCK LENGTH field (i.e., new logical block length) is different than the current logical block length this capacity setting 
shall take effect when the new logical block length takes effect (i.e., after a successful FORMAT UNIT command). 


The LOGICAL BLOCK LENGTH field specifies the length in bytes of each logical block. No change shall be made to any logical 
blocks on the medium until a format operation is initiated by an application client. 


A device server shall respond to a MODE SENSE command (see 3.11 and 3.12) by reporting the length of the logical blocks as 
specified in the LOGICAL BLOCK LENGTH field sent in the last MODE SELECT command that contained a mode parameter block 
descriptor. If no MODE SELECT command with a block descriptor has been received then the current logical block length shall be 
returned (e.g., if the logical block length is 512 bytes and a MODE SELECT command occurs with the LOGICAL BLOCK LENGTH 
field set to 520 bytes, any MODE SENSE command would return 520 in the LOGICAL BLOCK LENGTH field). To determine the 
logical block length at which the logical unit is currently formatted, the application client shall use the READ CAPACITY 
command rather than the MODE SELECT command. 
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5.3.5 Mode page and subpage formats and page codes 
The page_0O mode page format is defined in table 365. 


Table 365 Page_0 mode page format 









































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (Ob) PAGE CODE 
1 PAGE LENGTH (N-1) 
2 
MODE PARAMETERS 
n 














The SUB_PAGE mode page format is defined in table 366. 


Table 366 SUB_PAGE mode page format 


























Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (1b) PAGE CODE 
1 SUBPAGE CODE 
2 (MSB) 
PAGE LENGTH (N-3) ——J 
3 (LSB) 
4 
MODE PARAMETERS 
n 














Each mode page contains a PS bit, an SPF bit, a PAGE CODE field, a PAGE LENGTH field, and a set of mode parameters. The page 
codes are defined in this subclause and in the mode parameter subclauses in the command standard for the specific device type. 
Each mode page with a SPF bit set to one contains a SUBPAGE CODE field. 
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PS (parameters saveable) bit 


1 When using the MODE SENSE command, a parameters saveable (PS) bit set to one indicates that the mode page may be saved by the 
logical unit in a nonvolatile, vendor specific location. 


0 APS bit set to zero indicates that the device server is not able to save the supported parameters. When using the MODE SELECT com- 
mand, the PS bit is reserved. 


DS bit 
The DS bit is described in 5.2.2. 


SPF (SubPage Format) bit 
0 A SubPage Format (SPF) bit set to zero indicates that the page_0 mode page format is being used. 
1 A SPF bit set to one indicates that the SUB_PAGE mode page format is being used. 


PAGE CODE and SUBPAGE CODE fields 


The PAGE CODE and SUBPAGE CODE fields identify the format and parameters defined for that mode page. Some page codes are defined as 
applying to all device types and other page codes are defined for the specific device type. The page codes that apply to a specific device type 
are defined in the command standard for that device type. The applicability of each subpage code matches that of the page code with which it 
is associated. 


When using the MODE SENSE command, if page code 00h (vendor specific mode page) is implemented, the device server shall return that 
mode page last in response to a request to return all mode pages (page code 3Fh). When using the MODE SELECT command, this mode page 
should be sent last. 


PAGE LENGTH field 


The PAGE LENGTH field specifies the length in bytes of the mode parameters that follow. If the application client does not set this value to the 
value that is returned for the mode page by the MODE SENSE command, the command shall be terminated with CHECK CONDITION status, 
with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. The logical unit may imple- 
ment a mode page that is less than the full mode page length defined, provided no field is truncated and the PAGE LENGTH field correctly 
specifies the actual length implemented. 


MODE PARAMETERS 


The MODE PARAMETERS for each mode page are defined in the following subclauses, or in the mode parameters subclause in the command 
standard for the specific device type. MODE PARAMETERS not implemented by the logical unit shall be set to zero. 
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5.3.6 


Application Tag mode page (OAh/02h) 


Parameters for direct access devices 


The Application Tag mode page (see table 367) specifies the Application Tag that a device server configured for protection 
information (see 5.3.6) shall use for each LBA range if the ATO bit in the Control mode page (see 5.3.12) is set to one. The mode 
page policy (see 5.4.14) for this page shall be shared. 


Ifa method not defined by this standard changes the parameter data to be returned by the device server in the Application Tag 
mode page, then the device server shall establish a unit attention condition for the initiator port associated with every I_T nexus 
with the additional sense code set to MODE PARAMETERS CHANGED. 







































































Table 367 Application Tag mode page 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (1b) PAGE CODE (0Ah) 
1 SUBPAGE CODE(02h) 
2 (MSB) 
PAGE LENGTH (n - 3) 
3 (LSB) 
4 (MSB) 
a Reserved 
15 (LSB) 
Application Tag Descriptors 
16 
sai Application Tag descriptor (first) 
39 
n-24 
Application Tag descriptor (last) 
n 














The parameters saveable (PS) bit, the subpage format (SPF) bit, the PAGE CODE field, the SUBPAGE CODE field, and the PAGE 
LENGTH field are defined in SPC-5. 


The SPF bit, the PAGE CODE field, the SUBPAGE CODE field, and the PAGE LENGTH field shall be set to the values shown in Table 


367. 
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5.3.6.1 Application Tag descriptor 
The application tag descriptor format is described in Table 368. 


Table 368 Application Tag descriptor format 










































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 LAST Reserved 

1 

ate Reserved 

5 

6 (MSB) 

LOGICAL BLOCK APPLICATION TAG 

7 (LSB) 

8 (MSB) 

sais LOGICAL BLOCK ADDRESS 

15 (LSB) 

16 (MSB) 

wae LOGICAL BLOCK COUNT 

23 (LSB) 

LAST bit 
1 A LAST bit set to one specifies that this Application Tag descriptor is the last valid Application Tag descriptor in the Application Tag 
mode page. 


0 ALAST bit set to zero specifies that the Application Tag descriptor is not the last valid Application Tag descriptor in the Application Tag 
mode page. 


LOGICAL BLOCK APPLICATION TAG field 


The LOGICAL BLOCK APPLICATION TAG field specifies the value to be compared with the LOGICAL BLOCK APPLICATION TAG field associated 
with data read or written to the LBA. 


LOGICAL BLOCK ADDRESS field 


The LOGICAL BLOCK ADDRESS field contains the starting LBA for this Application Tag descriptor. The LOGICAL BLOCK ADDRESS field in the first 
Application Tag descriptor shall be set to 0000_0000_0000_0000h. For subsequent Application Tag descriptors, the contents of the LOGICAL 
BLOCK ADDRESS field shall contain the sum of the values in: 


a) the LOGICAL BLOCK ADDRESS field in the previous Application Tag descriptor; and 
b) the LOGICAL BLOCK COUNT field in the previous Application Tag descriptor. 


The sum of the LOGICAL BLOCK ADDRESS field in the Application Tag descriptor with the LAST bit set to one and the LOGICAL BLOCK COUNT 
field in the Application Tag descriptor with the LAST bit set to one shall equal the RETURNED LOGICAL BLOCK ADDRESS field in the READ 
CAPACITY (16) parameter data (see 3.23.2). 


If an invalid combination of the LAST bit, LOGICAL BLOCK APPLICATION TAG field, and LOGICAL BLOCK ADDRESS field are sent by the applica- 
tion client, then the device server shall terminate the MODE SELECT command (see 3.10) with CHECK CONDITION status with the sense key set 
to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST. The LOGICAL BLOCK COUNT field specifies the 
number of logical blocks to which this Application Tag descriptor applies. 

LOGICAL BLOCK COUNT field 


A LOGICAL BLOCK COUNT field set to 0000_0000_0000_0000h specifies that this Application Tag descriptor shall be ignored. 
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5.3.7 


Background Control mode page (1Ch/01h) 


Parameters for direct access devices 


The Background Control mode page (see table 369) is a subpage of the Informational Exception Control mode page (see 5.3.18) 


and provides controls over background operations. The mode page policy (see 5.4.14) for this subpage shall be shared. 










































































Table 369 Background Control mode page 
Bit 7 6 5 4 2 1 0 
Byte 
0 PS SPF(1b) PAGE CODE (1Ch) 
1 SUBPAGE CODE (01h) 
2 (MSB) 
PAGE LENGTH (000Ch) 
3 (LSB) 
4 Reserved S_L_FULL LOWIR EN_BMS 
5 Reserved EN_PS 
6 (MSB) 
BACKGROUND MEDIUM SCAN INTERVAL TIME 
7 (LSB) 
8 (MSB) 
BACKGROUND PRE-SCAN TIME LIMIT 
9 (LSB) 
10 (MSB) 
MINIMUM IDLE TIME BEFORE BACKGROUND SCAN 
11 (LSB) 
12 (MSB) 
MAXIMUM TIME TO SUSPEND BACKGROUND SCAN 
13 (LSB) 
14 
Reserved 
15 














PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The parameters saveable (PS) bit, the subpage format (SPF) bit, the PAGE CODE field, the SUBPAGE CODE field, and the PAGE LENGTH field are 
defined in 5.3.5. 


S_L_FULL bit 
0 Asuspend on log full (S_L_FULL) bit set to zero specifies that the device server shall continue running a background scan operation (see 
SPC-5) even if the Background Scan log page (see 5.2.4) contains the maximum number of Background Scan log parameters (see table 

277) supported by the logical unit. 

1 A S_L_FULL bit set to one specifies that the device server shall suspend a background scan operation if the Background Scan log page 
contains the maximum number of Background scan log parameters supported by the logical unit. 


LOWIR bit 
0 Alog only when intervention required (LOWIR) bit set to zero specifies that the device server shall log all suspected recoverable medium 


errors or unrecoverable medium errors that are identified during background scan operations in the Background Scan log page. 


1 A LOWIR bit set to one specifies that the device server shall only log medium errors identified during back ground scan operations in the 


Background Scan log page that require application client intervention. 
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EN_BMS (Enable Background Medium Scan) bit 
0 An enable background medium scan (EN_BMS) bit set to zero specifies that background medium scan is disabled. 


1 An EN_BMS bit set to one specifies that background medium scan operations are enabled. If the EN_PS bit is also set to one then a back- 
ground medium scan operation shall not start until after the pre-scan operation is halted or completed. 


If a background medium scan operation is in progress when the EN_BMS bit is changed from one to zero, then the logical unit shall suspend 
the background medium scan operation before the device server completes the MODE SELECT command, and the background medium scan 
shall remain suspended until the EN_BMS bit is set to one, at which time the background medium scan operation shall resume, beginning with 
the logical block being tested when the background medium scan was suspended. 


EN_PS (enable pre-scan) bit 


0 Anenable pre-scan (EN_PS) bit set to zero specifies that pre-scan is disabled. If a pre-scan operation is in progress when EN_PS is 
changed from a one to a zero then pre-scan is halted. 


1 An EN_PS bit set to one specifies that a pre-scan operation is started after the next power on cycle. 


Once this pre-scan has completed, another pre-scan shall not occur unless the EN_PS bit is set to zero, then set to one, and another power on 
cycle occurs. 


BACKGROUND MEDIUM SCAN INTERVAL TIME field 


The BACKGROUND MEDIUM SCAN INTERVAL TIME field specifies the minimum time, in hours, between the start of one pre-scan or background 
medium scan operation and the start of the next background medium scan operation. If the current background medium scan operation takes 
longer than the value specified in the BACKGROUND MEDIUM SCAN INTERVAL TIME field, then the logical unit shall: 
a) continue the current background pre-scan operation or background medium scan operation until that background scan operation is 
complete; and 
b) the logical unit shall start the next background medium scan operation starts upon completion of the current background pre-scan 
operation or background medium scan operation. 


BACKGROUND PRE-SCAN TIME LIMIT field 


The BACKGROUND PRE-SCAN TIME LIMIT field specifies the maximum time, in hours, for a background pre-scan operation to complete. If the 
background pre-scan operation does not complete within the specified time then the device server shall halt the background pre-scan opera- 
tion. A value of zero specifies an unlimited timeout value. 


MINIMUM IDLETIME BEFORE BACKGROUND SCAN field 


The MINIMUM IDLE TIME BEFORE BACKGROUND SCAN field specifies the time, in milliseconds, that the logical unit shall be idle after suspend- 
ing a background scan operation before resuming a background scan operation (e.g., after the device server has completed all of the com- 
mands in the task set). 


MAXIMUM TIME TO SUSPEND BACKGROUND SCAN field 


The MAXIMUM TIME TO SUSPEND BACKGROUND SCAN field specifies the time, in milliseconds, that the device server should take to start pro- 
cessing a command received while a logical unit is performing a background scan operation. 
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5.3.8 


Background Operation Control mode page (OAh/06h) 


Parameters for direct access devices 


The Background Operation Control mode page (see table 370) provides controls of device server background operation. 





















































Table 370 Background Operation Control mode page 

Bit 7 6 5 4 3 2 0 
Byte 

0 PS SPF (1b) PAGE CODE (0Ah) 

1 SUBPAGE CODE (06h) 

2 

_ PAGE LENGTH (01FDh) 

4 BO_MODE Reserved 

5 

Reserved 
n 














PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 
The parameters saveable (PS) bit, the subpage format (SPF) bit, the PAGE CODE field, the SUBPAGE CODE field, and the PAGE 


LENGTH field are defined in 5.3.5. 


BO_MODE field 


The background operation mode (BO_MODE) field specifies how host initiated advanced background operations shall operate 
during read operations or write operations as defined in table 371. 














Table 371 BO_MODE field 
Code Description 
00b Host initiated advanced background operation shall be suspended during read operations and write operations 
and resume advanced background operation when read operations and write operations are complete. 
01b Host initiated advanced background operation shall continue during read operations and write operations. 
All others Reserved 
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5.3.9 Caching Mode page (08h) 
The Caching Mode page for MODE SENSE/MODE SELECT defines the parameters that affect the use of the cache (see table 372). 


Table 372 Caching Mode page (08h) 
































































































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (Ob) PAGE CODE (08h) 
1 PAGE LENGTH (12h) 
2 IC ABPF CAP DISC SIZE WCE MF RCD 
3 DEMAND READ RETENTION PRIORITY WRITE RETENTION PRIORITY 
4 (MSB) 
DISABLE PREFETCH TRANSFER LENGTH 

5 (LSB) 
6 (MSB) 

MINIMUM PREFETCH 
7 (LSB) 
8 (MSB) 

MAXIMUM PREFETCH 
9 (LSB) 
10 (MSB) 

MAXIMUM PREFETCH CEILING 

11 (LSB) 
12 FSW LBCSS DRA Vendor specific SYNC_PROG NV_DIS 
13 NUMBER OF CACHE SEGMENTS 
14 (MSB) 

CACHE SEGMENT SIZE 
15 (LSB) 
16 Reserved 
17 (MSB) 

Obsolete 
19 (LSB) 
PS bit 


The returned Parameter Savable (PS) bit of 1 indicates that page 08h parameter data is savable. 


SPF bit, the PAGE CODE field and the PAGE LENGTH field 
The SPF bit, the PAGE CODE field and the PAGE LENGTH field shall be set to the values shown in table 372 for the Caching mode page. 


IC enable bit 
1 When the Initiator Control (IC) enable bit is set to one, adaptive read look-ahead (ARLA) is disabled. 


0 When ICis set to ZERO, ARLA is enabled. Since Seagate drives covered by this manual do not organize the cache according to size of seg- 
ment, but rather by number of segments, this bit is used to enable or disable ARLA (in non-Seagate equipment, this might be used to 
designate cache size). 


Note. ARLA cannot be disabled in some Seagate drives using the ASAII code. See individual drive’s Product Manual, Volume 1. 


ABPF bit 


1 The ABORT PREFETCH (ABPF) bit, when set to one, with the DRA bit equal to zero, requests that the SCSI device abort the PREFETCH 
upon selection. The ABPF set to one takes precedence over the Minimum PREFETCH bytes. 


0 When set to zero, with the DRA bit equal to zero, the termination of any active PREFETCH is dependent upon Caching Page bytes 4 
through 11 and is operation and/or vendor-specific. 
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CAP (Caching Analysis Permitted) bit 
1 The Caching Analysis Permitted (CAP) bit, when set to one, enables caching analysis. 


0 Azero indicates caching analysis is disabled. Caching analysis results are placed in the SCSI logging information table. 
See individual drive's Product Manual, Volume 1, SCSI Bus Conditions and Miscellaneous Features Supported table. 
DISC (Discontinuity) bit 


1 The Discontinuity (DISC) bit, when set to one, requests that the SCSI device continue the PREFETCH across time discontinuities, such as 
across cylinders or tracks up to the limits of the buffer, or segment, space available for PREFETCH. 


O When set to zero, the DISC requests that prefetches be truncated at time discontinuities. 


SIZE (Size Enable) bit 
1 The Size Enable (SIZE) bit, when set to one, indicates that the Cache Segment Size is to be used to control caching segmentation. 
QO When SIZE equals zero, the Initiator requests that the Number of Cache Segments is to be used to control caching segmentation. For 
Seagate drives covered by this manual, SIZE is always zero. 
WCE (Write Cache Enable) bit 
QO — SCSI WRITE commands may not return status and completion message bytes until all data has been written to the media. 


1 SCSI WRITE commands may return status and completion message bytes as soon as all data has been received from the host. 


MEF (Multiplication Factor) bit 

0 The Minimum PREFETCH and Maximum PREFETCH fields are interpreted as a number of logical blocks. 

1 Specifies that the target shall interpret the minimum and maximum PREFETCH fields to be specified in terms of a scalar number which, 
when multiplied by the number of logical blocks to be transferred for the current command, yields the number of logical blocks for each 
of the respective types of PREFETCH. 

RCD (READ Cache Disable) bit 
0 = SCSI READ commands may access the cache or the media. 


1 SCSI READ commands must access the media. Data cannot come from the cache. 


DEMAND READ RETENTION PRIORITY field 

DEMAND READ RETENTION PRIORITY. The cache replacement algorithm does not distinguish between retention in the cache of 
host-requested data and PREFETCH data. Therefore, this half byte is always 0. 

WRITE RETENTION PRIORITY field 

WRITE RETENTION PRIORITY. The cache replacement algorithm does distinguish between retention in the cache of host-requested data and 
PREFETCH data. Therefore, this half byte is always 0. 

DISABLE PREFETCH TRANSFER LENGTH field 

DISABLE PREFETCH TRANSFER LENGTH. PREFETCH is disabled for any SCSI READ command whose requested transfer length exceeds this value. 


MINIMUM PREFETCH field 


The MINIMUM PREFETCH specifies the minimum number sectors to prefetch, regardless of the delay it may cause to other commands. 


MAXIMUM PREFETCH field 

The MAXIMUM PREFETCH specifies the maximum number of logical blocks that may be prefetched. The PREFETCH operation may be aborted 
before the MAXIMUM PREFETCH value is reached, but only if the MINIMUM PREFETCH value has been satisfied. 

MAXIMUM PREFETCH CEILING field 


The MAXIMUM PREFETCH Ceiling specifies an upper limit on the number of logical blocks computed as the maximum prefetch. If the MAXI- 
MUM PREFETCH value is greater than the MAXIMUM PREFETCH CEILING, the value is truncated to the MAXIMUM PREFETCH CEILING value. 
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FSW (FORCE SEQUENTIAL WRITE) bit 


1 The Force Sequential Write (FSW) bit, when set to one, indicates that multiple block writes are to be transferred over the SCSI bus and 
written to the media in an ascending, sequential, logical block order. 


0 When the FSW bit equals zero, the target is allowed to reorder the sequence of writing addressed logical blocks in order to achieve a 
faster command completion. 


LBCSS bit 
1 A logical block cache segment size (LBCSS) bit set to one specifies that the CACHE SEGMENT SIZE field units shall be interpreted as logi- 
cal blocks. 


0 = AnLBCSS bit set to zero specifies that the CACHE SEGMENT SIZE field units shall be interpreted as bytes. The LBCSS shall not impact the 
units of other fields. 


DRA (Disable READ-Ahead) bit 


1 The Disable READ-Ahead (DRA) bit, when set to one, requests that the target not read into the buffer any logical blocks beyond the 
addressed logical block(s). 


O When the DRA bit equals zero, the target may continue to read logical blocks into the buffer beyond the addressed logical block(s). 


SYNC_PROG field 


The synchronize cache progress indication support (SYNC_PROG) field specifies device server progress indication reporting for the 
SYNCHRONIZE CACHE commands as defined in 3.52. 


NV_DIS bit 
1 An NV_DIS bit set to one specifies that the device server shall disable a non-volatile cache and indicates that a non-volatile cache is sup- 
ported but disabled. 


0 AnNV_DIS bit set to zero specifies that the device server may use a non-volatile cache and indicates that a non-volatile cache may be 
present and enabled. 


NUMBER OF CACHE SEGMENTS byte 
The NUMBER OF CACHE SEGMENTS byte gives the number of segments into which the host requests the drive divide the cache. 


CACHE SEGMENT SIZE field 


The CACHE SEGMENT SIZE field indicates the requested segment size in bytes. This manual assumes that the Cache Segment Size field is valid 
only when the Size bit is one. 


SCSI Commands Reference Manual, Rev. J 393 


www.seagate.com Parameters for direct access devices 


5.3.10 Command Duration Limit A mode page (OAh/03h) 


The Command Duration Limit A mode page (see table 373) provides controls for command duration limit (see SAM-5) that are 
applicable to all device types, for commands for which the REPORT SUPPORTEDOPERATION CODES command parameter data 
CDLP field (see 3.34) indicates the Command Duration Limit A mode page. The mode page policy (see 3.9) for this mode page 
should be per I_T nexus. The mode page policy may be shared. If a field in this mode page is changed while there is a command 
already in the task set, then the new value of the field shall not apply to that command. 


Table 373. Command Duration Limit A mode page 




































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PS SPF (1b) PAGE CODE (0Ah) 

1 SUBPAGE CODE(03h) 

2 (MSB) 

PAGE LENGTH (0020h) 

3 (LSB) 

4 

sists Reserved 

7 

Command duration limit descriptor list 

8 

oe Command duration limit descriptor (first) 

11 

12 

se Command duration limit descriptor (second) 

15 

32 

wae Command duration limit descriptor (last) 

35 











PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The parameters saveable (PS) bit, the subpage format (SPF) bit, the PAGE CODE field, the SUBPAGE CODE field, and the PAGE LENGTH field are 
defined in 5.3.5 and shall be set as shown in table 411 for the Command Duration Limit A mode page. 


Command duration limit descriptor fields 


The command duration limit descriptor (see table 374) describes the command duration limit corresponding to the duration limit descriptor 
value in the CDB (see appropriate command standard). 
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EXAMPLE - A duration limit descriptor value of 001b selects the command duration limit contained in the first command 
duration limit descriptor, a duration limit descriptor value of 010b selects the command duration limit contained in the second 
command duration limit descriptor, and a duration limit descriptor value of 111b selects the command duration limit contained 
in the seventh command limit duration descriptor. 


Table 374 Command Duration Limit A mode page 






































Bit 7 6 5 4 3 2 1 0 
Byte 
0 CDLUNIT Reserved 
1 Reserved 
2 (MSB) 
COMMAND DURATION LIMIT 
3 (LSB) 














CDLUNIT field 
The CDLUNIT field (see table 375) specifies the time units for this command duration limit descriptor. 


COMMAND DURATION LIMIT field 


A COMMAND DURATION LIMIT field set to a non-zero value specifies the command duration limit in units specified by the CDLUNIT field. A 
COMMAND DURATION LIMIT field set to zero specifies that no command duration limit is specified by the command duration limit descriptor. If 
the CDLUNIT field is set to 000b, the COMMAND DURATIONLIMIT field shall be ignored. 


Table 375 CDLUNIT field 





Code Description 





000b No duration limit is specified 





100b 1 microsecond 





101b 10 milliseconds 





110b 500 milliseconds 





Allothers | Reserved 














SCSI Commands Reference Manual, Rev. J 395 


www.seagate.com Parameters for direct access devices 


5.3.11 Command Duration Limit B mode page (OAh/04h) 


The Command Duration Limit B mode page (see table 376) provides controls for command duration limit (see SAM-5) that are 
applicable to all device types, for commands for which the REPORT SUPPORTEDOPERATION CODES command parameter data 
CDLP field (see 3.34) indicates the Command Duration Limit B mode page. The mode page policy (see 3.9) for this mode page 
should be per I_T nexus. The mode page policy may be shared. If a field in this mode page is changed while there is a command 
already in the task set, then the new value of the field shall not apply to that command. 


Table 376 Command Duration Limit B mode page 




































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PS SPF (1b) PAGE CODE (OAh) 

1 SUBPAGE CODE(04h) 

2 (MSB) 

PAGE LENGTH (0020h) 

3 (LSB) 

4 

sists Reserved 

7 

Command duration limit descriptor list 

8 

oe Command duration limit descriptor (first) 

11 

12 

se Command duration limit descriptor (second) 

15 

32 

wae Command duration limit descriptor (last) 

35 











PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The parameters saveable (PS) bit, the subpage format (SPF) bit, the PAGE CODE field, the SUBPAGE CODE field, and the PAGE LENGTH field are 
defined in 5.3.5 and shall be set as shown in table 414 for the Command Duration Limit B mode page. 


Command duration limit descriptor fields 


The command duration limit descriptor (see table 374) describes the command duration limit corresponding to the duration limit descriptor 
value in the CDB (see appropriate command standard). 
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5.3.12 


Control mode page (0Ah) 


Parameters for direct access devices 


The Control mode page (see table 377) provides controls over SCSI features that are applicable to all device types (e.g., task set 
management and error logging). If a field in this mode page is changed while there is a task already in the task set, it is vendor 
specific whether the old or new value of the field applies to that task. The mode page policy (see 3.9) for this mode page shall be 


shared, or per |_T nexus. 




































































Table 377 Control mode page 
Bit 7 6 4 3 2 1 0 
Byte 
0 PS SPF (0b) PAGE CODE (0Ah) 
1 PAGE LENGTH (0Ah) 
2 TST TMF_ONLY DPICZ D_SENSE GLTSD RLEC 
3 QUEUE ALGORITHM MODIFIER NUAR QERR POUE 
Obsolete 
RAERP UAAERP EAERP 
. ae UAINTLCKCCTRL an Obsolete Obsolete Obsolete 
5 ATO RWWP Reserved AUTOLOAD MODE 
2 (MSB) Obsolete formerly 
7 READY AER HOLDOFF PERIOD (LSB) 
8 (MSB) 
BUSY TIMEOUT PERIOD 
9 (LSB) 
10 (MSB) 
EXTENDED SELF-TEST COMPLETION TIME 
11 (LSB) 














PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field 


The PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field are described in 5.3.5. 


TST (task set type) field 
A task set type (TST) field specifies the type of task set in the logical unit (see table 378). 


Table 378 Task set type (TST) field 


Code 





ae 


Regardless of the mode page policy (see 5.4.14) for the Control mode page, the shared mode page policy shall be applied to the 
TST field. If the most recent MODE SELECT changes the setting of this field, then the device server shall establish a unit attention 
condition (see SAM-5) for the initiator port associated with every I_T nexus except the I_T nexus on which the MODE SELECT 
command was received, with the additional sense code set to MODE PARAMETERS CHANGED. 
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TMF_ONLY (Allow Task Management Functions Only) bit 


0 ‘The allow task management functions only (TMF_ONLY) bit set to zero specifies that the device server shall process tasks with the ACA 
task attribute received on the faulted |_T nexus when an ACA condition has been established (see SAM-5). 


1 A TMF_ONLY bit set to one specifies that the device server shall terminate all tasks received on the faulted |_T nexus with an ACA ACTIVE 
status when an ACA condition has been established. 


DPICZ bit 


0 = Adisable protection information check if protect field is zero (DPICZ) bit set to zero indicates that checking of protection information 
bytes is enabled. 


1 A DPICZ bit set to one indicates that checking of protection information is disabled on commands with: 
a) the RDPROTECT field (see SBC-4) set to zero; 
b) the VRPROTECT field (see SBC-4) set to zero; or 
c) the ORPROTECT field (see SBC-4) set to zero. 


D_SENSE (DESCRIPTOR FORMAT SENSE DATA) bit 


0 A descriptor format sense data (D_SENSE) bit set to zero specifies that the device server shall return the fixed format sense data when 
returning sense data in the same I_T_L_Q nexus transaction as a CHECK CONDITION status. 


1 A D_SENSE bit set to one specifies that the device server shall return descriptor format sense data when returning sense data in the 
same |_T_L_Q nexus transaction as a CHECK CONDITION status, except as defined in 2.4.1. 
GLTSD (Global Logging Target Save Disable) bit 


0 =A global logging target save disable (GLTSD) bit set to zero specifies that the logical unit implicitly saves, at vendor specific intervals, 
each log parameter in which the TSD bit (see 5.2) is set to zero. 


1 AGLTSD bit set to one specifies that the logical unit shall not implicitly save any log parameters. 


RLEC (Report Log Exception Condition) bit 


1 A report log exception condition (RLEC) bit set to one specifies that the device server shall report log exception conditions as described 
in 5.2.2. 


0  ARLEC bit set to zero specifies that the device server shall not report log exception conditions. 


QUEUE ALGORITHM MODIFIER field 


The QUEUE ALGORITHM MODIFIER field (see table 379) specifies restrictions on the algorithm used for reordering tasks having the SIMPLE task 
attribute (see SAM-5). 


Table 379 QUEUE ALGORITHM MODIFIER field 











Code Description 
Oh Restricted reordering 
th Unrestricted reordering allowed 





2h-7h Reserved 














8h-Fh Vendor specific 





A value of zero in the QUEUE ALGORITHM MODIFIER field specifies that the device server shall order the processing sequence of tasks having 
the SIMPLE task attribute such that data integrity is maintained for that |_T nexus (i.e., if the transmission of new SCSI transport protocol 
requests is halted at any time, the final value of all data observable on the medium shall have exactly the same value as it would have if all the 
tasks had been given the ORDERED task attribute). 


A value of one in the QUEUE ALGORITHM MODIFIER field specifies that the device server may reorder the processing sequence of tasks having 
the SIMPLE task attribute in any manner. Any data integrity exposures related to task sequence order shall be explicitly handled by the applica- 
tion client through the selection of appropriate commands and task attributes. 
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NUAR bit 


1 A no unit attention on release (NUAR) bit set to one specifies that the device server shall not establish a unit attention condition as 
described in 5.13.11.2.2. 


O  ANUAR bit set to zero specifies that the device server shall establish a unit attention condition as described in SPC-5. 


QERR (queue error management) field 


The queue error management (QERR) field (see table 380) specifies how the device server shall handle other tasks when one task is terminated 
with CHECK CONDITION status (see SAM-5). The task set type (see the TST field definition in this subclause) defines which other tasks are 
affected. If the TST field equals 000b, then all tasks from all |_T nexuses are affected. If the TST field equals 001b, then only tasks from the same 
|_T nexus as the task that is terminated with CHECK CONDITION status are affected. 


Table 380 Queue error management (QERR) field 





Code Definition 





If an ACA condition is established, the affected tasks in the task set shall resume after the ACA condition is cleared 
00b (see SAM-5). Otherwise, all tasks other than the task that received the CHECK CONDITION status shall be pro- 
cessed as if no error occurred. 


All the affected tasks in the task set shall be aborted when the CHECK CONDITION status is sent. If the TAS bit is set 
to zero, a unit attention condition (see SAM-5) shall be established for the initiator port associated with every |_T 
nexus that had tasks aborted except for the |_T nexus on which the CHECK CONDITION status was returned, with 
01b the additional sense code set to COMMANDS CLEARED BY ANOTHER INITIATOR. If the TAS bit is set to one, all 
affected tasks in the task set for |_T nexuses other than the |_T nexus for which the CHECK CONDITION status was 
sent shall be completed with a TASK ABORTED status and no unit attention shall be established. For the |_T nexus 
to which the CHECK CONDITION status is sent, no status shall be sent for the tasks that are aborted. 


10b Reserved 











Affected tasks in the task set belonging to the |_T nexus on which a CHECK CONDITION status is returned shall be 


11b : 
aborted when the status is sent. 














DQUE (Disable Queuing) bit 
NOTE The DQUE bit has been declared obsolete by the T10 committee and is not supported. 


VS bit 
QO The VENDOR SPECIFIC (VS) bit is not supported in Seagate products. 


RAC (report a check) bit 


1 The report a check (RAC) bit provides control of reporting long busy conditions or CHECK CONDITION status. A RAC bit set to one speci- 
fies that the device server should return CHECK CONDITION status rather than returning BUSY status if the reason for returning the BUSY 
status may persist for a longer time than that specified by the AUTOLOAD MODE field. 


0 ARAC bit set to zero specifies that the device server may return BUSY status regardless of the length of time the reason for returning 
BUSY status may persist. 
UA_INTLCK_CTRL (unit attention interlocks control) field 


The unit attention interlocks control (UA_INTLCK_CTRL) field (see table 381) controls the clearing of unit attention conditions reported in the 
same |_T_L_Q nexus transaction as a CHECK CONDITION status and whether returning a status of BUSY, TASK SET FULL or RESERVATION CON- 
FLICT results in the establishment of a unit attention condition (see SAM-5). 
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Table 381 ~—Unit attention interlocks control (UA_INTLCK_CTRL) field 











Code Definition 
The logical unit shall clear any unit attention condition reported in the same |_T_L_Q nexus transaction as a CHECK CONDITION 
00b status and shall not establish a unit attention condition when a task is terminated with BUSY, TASK SET FULL, or RESERVATION 
CONFLICT status. 
01b Reserved /@! 





The logical unit shall not clear any unit attention condition reported in the same |_T_L_Q nexus transaction as a CHECK CONDI- 
10b [a] TION status and shall not establish a unit attention condition when a task is terminated with BUSY, TASK SET FULL, or RESERVA- 
TION CONFLICT status. 


The logical unit shall not clear any unit attention condition reported in the same |_T_L_Q nexus transaction as a CHECK CONDI- 
TION status and shall establish a unit attention condition for the initiator port associated with the I_T nexus on which the BUSY, 
TASK SET FULL, or RESERVATION CONFLICT status is being returned. Depending on the status, the additional sense code shall be 
set to PREVIOUS BUSY STATUS, PREVIOUS TASK SET FULL STATUS, or PREVIOUS RESERVATION CONFLICT STATUS. Until it is 
cleared by a REQUEST SENSE command, a unit attention condition shall be established only once for a BUSY, TASK SET FULL, or 
RESERVATION CONFLICT status regardless to the number of commands terminated with one of those status values. 


11b [a] 














[a] A REQUEST SENSE command still clears any unit attention condition that it reports. 





SWP (Software Write Protect) bit 


1 A software write protect (SWP) bit set to one specifies that the logical unit shall inhibit writing to the medium after writing all cached or 
buffered write data, if any. When SWP is one, all commands requiring writes to the medium shall be terminated with CHECK CONDITION 
status, with the sense key set to DATA PROTECT, and the additional sense code set to WRITE PROTECTED. When SWP is one and the 
device type's command standard defines a write protect (WP) bit in the DEVICE-SPECIFIC PARAMETER field in the mode parameter 
header, the WP bit shall be set to one for subsequent MODE SENSE commands. 


0 A SWP bit set to zero specifies that the logical unit may allow writing to the medium, depending on other write inhibit mechanisms 
implemented by the logical unit. When the SWP bit is set to zero, the value of the WP bit, if defined, is device type specific. For a list of 
commands affected by the SWP bit and details of the WP bit see the command standard for the specific device type. 


RAERP, UAAERP, and EAERP bits 


NOTE _ These three bits have been declared obsolete by the T10 committee and are not supported. 


RAERP (Ready AER Permission) bit (obsolete) 


1 A Ready AER Permission (RAERP) bit of one specifies that the target may issue an asynchronous event report upon completing its initial- 
ization sequence instead of generating a unit attention condition. 


O  ARAERP bit of zero specifies that the target shall not issue an asynchronous event report upon completing its initialization sequence. 


UAAERP (UNIT ATTENTION AER Permission) bit (obsolete) 


1 A UNIT ATTENTION AER Permission (UAAERP) bit of one specifies that the target may issue an asynchronous event report instead of cre- 
ating a unit attention condition upon detecting an unit attention condition event (other than upon completing an initialization 
sequence). 


O AUAAERP bit of zero specifies that the target shall not issue an asynchronous event reporting instead of creating a unit attention condi- 
tion. 
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EAERP (Error AER Permission) bit (obsolete) 


1 An Error AER Permission (EAERP) bit of one specifies that the target may issue an asynchronous event report upon detecting a deferred 
error condition instead of waiting to report the deferred error on the next command. 


O An EAERP bit of zero specifies that the target shall not report deferred error conditions via an asynchronous event reporting. 


ATO (application tag owner) bit 


1 An application tag owner (ATO) bit set to one specifies that the contents of the LOGICAL BLOCK APPLICATION TAG field in the protection 
information, if any, shall not be modified by the device server. 


0 = AnATO bit set to zero specifies that the contents of the LOGICAL BLOCK APPLICATION TAG field in the protection information, if any, may 
be modified by the device server. If the ATO bit is set to zero, the device server shall ignore the contents of the LOGICAL BLOCK APPLICA- 
TION TAG field in the protection information when received from the application client. 


TAS (Task Aborted Status) bit 


0A task aborted status (TAS) bit set to zero specifies that aborted tasks shall be terminated by the device server without any response to 
the application client. 


1 A TAS bit set to one specifies that tasks aborted by the actions of an |_T nexus other than the I_T nexus on which the command was 
received shall be terminated with a TASK ABORTED status (see SAM-5). 


ATMPE bit 


0 = Anapplication tag mode page enabled (ATMPE) bit set to zero specifies that the Application Tag mode page (see 5.3.6) is disabled and 
the contents of logical block application tags are not defined by this standard. 


1 An ATMPE bit set to one specifies that the Application Tag mode page is enabled. 
If: 
a) the ATMPE is set to one; 
b) the ATO bit is set to one; 
c) the value in the DPICZ bit allows protection information checking for the specified command; and 
d) the APP_CHK bit is set to one in the Extended INQUIRY VPD page (see 5.4.9); 
then: 


knowledge of the value of the Application Tag shall come from the values in the Application Tag mode page as specified by the DPICZ 
bit. 


SCSI Commands Reference Manual, Rev. J 401 


www.seagate.com Parameters for direct access devices 


RWWP bit 


0 = Areject write without protection (RWWP) bit set to zero specifies that the device server shall process write commands that are specified 
to include user data without protection information (e.g.,a WRITE(10) command with the WRPROTECT field set to 000b (see 3.60)). 


1 A RWWP bit set to one specifies that the device server in a logical unit that has been formatted with protection information shall termi- 
nate with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN 
CDB any write command that is specified to include user data without protection information. 
AUTOLOAD MODE field 
The AUTOLOAD MODE field specifies the action to be taken by a removable medium device server when a medium is inserted. For devices 
other than removable medium devices, this field is reserved. Table 382 shows the usage of the AUTOLOAD MODE field. 


Table 382 AUTOLOAD MODE field 

















Code Definition 
000b Medium shall be loaded for full access. 
001b Medium shall be loaded for medium auxiliary memory access only. 
010b Medium shall not be loaded. 

011b-111b | Reserved 














READY AER HOLDOFF PERIOD field 


NOTE This field has been declared obsolete by the T10 committee and are not supported. 


BUSY TIMEOUT PERIOD field 


The BUSY TIMEOUT PERIOD field specifies the maximum time, in 100 milliseconds increments, that the application client allows for the device 
server to return BUSY status for unanticipated conditions that are not a routine part of commands from the application client. This value may 
be rounded down as defined in Clause 2.3. A 0000h value in this field is undefined by this manual. An FFFFh value in this field is defined as an 
unlimited period. 


EXTENDED SELF-TEST COMPLETION TIME field 


The EXTENDED SELF-TEST COMPLETION TIME field contains advisory data that is the time in seconds that the device server requires to com- 
plete an extended self-test when the device server is not interrupted by subsequent commands and no errors occur during processing of the 
self-test. The application client should expect this time to increase significantly if other commands are sent to the logical unit while a self-test is 
in progress or if errors occur during the processing of the self-test. Device servers supporting SELF-TEST CODE field values other than 000b for 
the SEND DIAGNOSTIC command (see 3.46) shall support the EXTENDED SELF-TEST COMPLETION TIME field. The EXTENDED SELF-TEST COM- 
PLETION TIME field is not changeable. 
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5.3.13 


Control Extension mode page (OAh/01h) 


Parameters for direct access devices 


The Control Extension mode page (see table 383) is a subpage of the Control mode page (see 5.3.12) and provides controls over 
SCSI features that are applicable to all device types. The mode page policy (see 5.4.14) for this mode page shall be shared. If a 
field in this mode page is changed while there is a task already in the task set, it is vendor specific whether the old or new value 
of the field applies to that task. 

































































Table 383 Control Extension mode page 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (1b) PAGE CODE (0Ah) 
1 SUBPAGE CODE (01h) 
2 (MSB) 
PAGE LENGTH (1Ch) 
3 (LSB) 
4 Reserved TCMOS SCSIP IALUAE 
5 Reserved INITIAL COMMAND PRIORITY 
6 MAXIMUM SENSE DATA LENGTH 
7 
Reserved 
31 
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The PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 5.3.5. 


TCMOS (Timestamp Changeable By Methods Outside this manual) bit 


1 A timestamp changeable by methods outside this manual (TCMOS) bit set to one specifies that the timestamp may be initialized by 
methods outside the scope of this manual. 


0 ATCMOS bit set to zero specifies that the timestamp shall not be changed by any method except those defined by this manual. 


SCSIP (SCSI precedence) bit 


1 A SCSI precedence (SCSIP) bit set to one specifies that the timestamp changed using a SET TIMESTAMP command shall take precedence 
over methods outside the scope of this manual. 


0 = ASCSIP bit set to zero specifies that methods outside this manual may change the timestamp and that the SET TIMESTAMP command is 
illegal. 


IALUAE (Implicit Asymmetric Logical Unit Access Enabled) bit 
1 An Implicit Asymmetric Logical Unit Access Enabled (IALUAE) bit set to one specifies that implicit asymmetric logical unit access state 
changes are allowed. 


0 An IALUAE bit set to zero specifies that implicit asymmetric logical unit access state changes be disallowed and indicates that implicit 
asymmetric logical unit access state changes are disallowed or not supported. 


INITIAL COMMAND PRIORITY field 

The INITIAL COMMAND PRIORITY field specifies the priority that may be used as the task priority (see SAM-5) for tasks received by the logical 
unit on any |_T nexus (i.e., on any |_T_L nexus) where a priority has not been modified by a SET PRIORITY command. If a MODE SELECT com- 
mand specifies an INITIAL COMMAND PRIORITY value that is different than the current INITIAL PRIORITY, then the device server shall set any pri- 
orities that have not be set with a SET PRIORITY command to a value different than the new initial priority value to the new priority. The device 
server shall establish a unit attention condition for the initiator port associated with every |_T_L nexus that receives a new priority, with the 
additional sense code set to PRIORITY CHANGED. 


MAXIMUM SENSE DATA LENGTH field 


The MAXIMUM SENSE DATA LENGTH field specifies the maximum number of bytes of sense data the device server shall return in the same 
|_T_L_Q nexus transaction as the status. A MAXIMUM SENSE DATA LENGTH field set to zero specifies that there is no limit. The device server 
shall not return more sense data bytes in the same |_T_L_Q nexus transaction as the status than the smaller of the length indicated by the: 


a) MAXIMUM SENSE DATA LENGTH field; and 
b) MAXIMUM SUPPORTED SENSE DATA LENGTH field in the Extended INQUIRY VPD page (see 5.4.9). 
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5.3.14 Disconnect-Reconnect mode page (02h) for FC 


The Disconnect-Reconnect mode page for FCP (see table 384) allows the application client to modify the behavior of the service 
delivery subsystem. This subclause specifies the parameters that are used by FCP devices and defines how FCP devices interpret 
the parameters. The application client communicates with the device server to determine what values are most appropriate fora 
device server. The device server communicates the parameter values in this mode page to the target FCP_Port, normally the 
Fibre Channel interface circuitry. This communication is internal to the SCSI target device and FCP device and is outside the 
scope of this manual. If a field or bit contains a value that is not supported by the FCP device, the device server shall return 
CHECK CONDITION status. The sense key shall be set to ILLEGAL REQUEST and the additional sense code set to ILLEGAL FIELD IN 
PARAMETER LIST. 


Table 384 Disconnect-Reconnect mode page (02h) 

























































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PS SPF (Ob) PAGE CODE (02h) 
1 PAGE LENGTH (OEh) 
2 BUFFER FULL RATIO 
3 BUFFER EMPTY RATIO 
4 (MSB) 

BUS INACTIVITY LIMIT 
5 (LSB) 
6 (MSB) 

DISCONNECT TIME LIMIT 

7 (LSB) 
8 (MSB) 

CONNECT TIME LIMIT 
9 (LSB) 
10 (MSB) 

MAXIMUM BURST SIZE 
11 (LSB) 
12 EMDP FAA FAB FAC Restricted Restricted 
13 Reserved 
14 (MSB) 

FIRST BURST SIZE ——— 

15 (LSB) 














An interconnect tenancy is the period of time when an FCP device owns or may access a shared Fibre Channel interconnect. For 
arbitrated loops (see FC-AL-2) and Fibre Channel Class 1 connections, a tenancy typically begins when an FCP device successfully 
opens the connection and ends when the FCP device releases the connection for use by other device pairs. Data and other 
information transfers take place during interconnect tenancies. 


Point-to-point or fabric-attached Class 2 or Class 3 links and many other configurations do not have a concept of interconnect 
tenancy and may perform transfers at any time. 
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BUFFER FULL RATIO field 


The BUFFER FULL RATIO field indicates to the device server, during read operations, how full the buffer should be prior to requesting an inter- 
connect tenancy. Device servers that do not implement the requested ratio should round down to the nearest implemented ratio as defined in 
2.3. FCP devices attached to links that do not have the concept of interconnect tenancy shall round the ratio to zero and transmit data in a ven- 
dor specific manner. 


The value contained in the BUFFER FULL RATIO field is defined by 5.3.14. 


BUFFER EMPTY RATIO field 


The BUFFER EMPTY RATIO field indicates to the device server, during write operations, how empty the buffer should be prior to transmitting an 
FCP_XFER_RDY IU that requests the initiator FCP_Port to send data. Device servers that do not implement the requested ratio should round 
down to the nearest implemented ratio as defined in 2.3. 


The value contained in the BUFFER EMPTY RATIO field is defined by 5.3.14. 


BUS INACTIVITY LIMIT field 


The BUS INACTIVITY LIMIT field indicates the maximum time that the target FCP_Port is permitted to maintain an interconnect tenancy with- 
out data or information transfer, measured in transmission word increments. If the bus inactivity limit is exceeded or if the bus is inactive and 
the target FCP_Port holding the bus detects that the limit is going to be exceeded, the device server shall end the interconnect tenancy. This 
value may be rounded as defined in 2.3. A value of zero indicates that there is no bus inactivity limit. 


Note. Because of the low overheads associated with initiating and closing bus tenancy on Fibre Channel links, device servers should end ten- 
ancies immediately upon completing the required transfers. 


The BUS INACTIVITY LIMIT field is not applicable for FCP devices attached to links that do not have the concept of interconnect tenancy. 


DISCONNECT TIME LIMIT field 


The DISCONNECT TIME LIMIT field indicates the minimum delay between interconnect tenancies measured in increments of 128 transmission 
words. Target FCP_Ports in configurations having the concept of interconnect tenancy shall delay at least this time interval after each intercon- 
nect tenancy before beginning arbitration. The device server may round this value to any value it prefers. A value of zero indicates that the dis- 
connect time limit does not apply. 


The DISCONNECT TIME LIMIT field is not applicable for FCP devices attached to links that do not have the concept of interconnect tenancy. 


CONNECT TIME LIMIT field 


The CONNECT TIME LIMIT field indicates the maximum duration of a single interconnect tenancy, measured in increments of 128 transmission 
words. If the connect time limit is exceeded the device server shall conclude the interconnect tenancy, within the restrictions placed on it by 
the applicable Fibre Channel configuration. The device server may round this value to any value it prefers. A value of zero indicates that there is 
no connect time limit. 


The CONNECT TIME LIMIT field is not applicable for FCP devices attached to links that do not have the concept of interconnect tenancy. 


MAXIMUM BURST SIZE field 


The MAXIMUM BURST SIZE field indicates the maximum size of all bytes in an FCP_DATA IU that the target FCP_Port shall transfer to the initia- 
tor FCP_Port in a single Data-In FCP_DATA IU or request from the initiator FCP_Port in an FCP_XFER_RDY IU. This parameter does not affect 
how much data is transferred in a single interconnect tenancy. This value is expressed in increments of 512 bytes (e.g., a value of 1 means 512 
bytes, two means 1024 bytes, etc.). The device server may round this value down as defined in 2.3. A value of zero indicates there is no limit on 
the amount of data transferred per data transfer operation. This value shall be implemented by all FCP devices. The initiator FCP_Port and tar- 
get FCP_Port may use the value of this parameter to adjust internal maximum buffering requirements. 
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EMDP bit 


The enable modify data pointers (EMDP) bit indicates whether or not the target FCP_Port may use the random buffer access capability to reor- 
der FCP_DATA IUs for a single SCSI command. If the EMDP bit is set to zero, the target FCP_Port shall generate continuously increasing relative 
offset values for each FCP_DATA IU for a single SCSI command. 


1 If the EMDP bit is set to one, the target FCP_Port may transfer the FCP_DATA IUs for a single SCSI command in any order. 


0 If the EMDP bit is set to zero, data overlay is prohibited even if it is allowed by the state of the PRLI FCP Service Parameter page DATA 
OVERLAY ALLOWED bit. 


The EMDP bit does not affect the order of frames within a Sequence. The enable modify data pointers function is optional for all FCP devices. 


For bidirectional commands, the EMDP bit applies independently to the read operation and write operation. If the EMDP bit is set to zero, the 
target FCP_Port shall generate continuously increasing relative offset values for the read operation and the write operation, but there is no 
read operation to write operation or write operation to read operation ordering requirement. 


FAA, FAB, FAC bits 
The fairness access (FA) bits, FAA, FAB, and FAC, indicate whether a target FCP_Port attached to an arbitrated loop (see FC-AL-2) shall use the 
access fairness algorithm when beginning the interconnect tenancy. 
1 An FA bit set to one indicates that the target FCP_Port shall use the access fairness algorithm for the specified frames. 
0 AnFA bit set to zero indicates that the target FCP_Port may choose to not use the access fairness algorithm. 
The FAA bit controls arbitration when the target FCP_Port has one or more FCP_DATA IU frames to send to an initiator FCP_Port. 
The FAB bit controls arbitration when the target FCP_Port has one or more FCP_XFER_RDY IU frames to send to an initiator FCP_Port. 
The FAC bit controls arbitration when the target FCP_Port has an FCP_RSP IU frame to send to an initiator FCP_Port. 


If the target FCP_Port intends to send multiple frame types, it may choose to not use the access fairness algorithm if any applicable FA bit is set 
to zero. FCP devices attached to links that do not have the concept of interconnect tenancy shall ignore the FA bits. The FA bits are optional for 
all FCP devices. 


FIRST BURST SIZE field 


When the WRITE FCP_XFER_RDY DISABLED bit is negotiated as being set to one in the PRLI FCP Service Parameter page, the FIRST BURST SIZE 
field indicates the maximum amount of all bytes that shall be transmitted in the first FCP_DATA IU sent from the initiator FCP_Port to the target 
FCP_Port. If all data is transmitted in the first IU, no subsequent FCP_XFER_RDY 1Us shall be transmitted by the target FCP_Porrt. If the maximum 
amount of data has been transmitted, but more data remains to be transferred, the target FCP_Port shall request that data with subsequent 
FCP_XFER_RDY IUs. 


When the WRITE FCP_XFER_RDY DISABLED bit is negotiated as being set to zero in the PRLI FCP Service Parameter page, the FIRST BURST SIZE 
field is ignored and permission to transmit data from the initiator FCP_Port to the target FCP_Port is managed using FCP_XFER_RDY IUs. For 
data transmissions from the target FCP_Port to the initiator FCP_Port, the FIRST BURST SIZE field is ignored. 


The FIRST BURST SIZE field value is expressed in increments of 512 bytes (e.g., a value of one means 512 bytes, two means 1024 bytes). A value 
of zero indicates that there is no first burst size limit. The FIRST BURST SIZE field shall be implemented by all FCP devices that support the WRITE 
FCP_XFER_RDY DISABLED bit being set to one. The application client and device server may use the value of this parameter to adjust internal 
maximum buffering requirements. 
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5.3.15 Disconnect-Reconnect mode page (02h) for SAS 


The Disconnect-Reconnect mode page for SAS provides the application client the means to tune the performance of the service 
delivery subsystem. Table 385 defines the parameters which are applicable to SSP. If any field in the Disconnect-Reconnect mode 
page is not implemented, the value assumed for the functionality of the field shall be zero (i.e., as if the field in the mode page is 
implemented and the field is set to zero). 


The application client sends the values in the fields to be used by the device server to control the SSP connections by means of a 
MODE SELECT command. The device server shall then communicate the field values to the SSP target port. The field values are 
communicated from the device server to the SSP target port in a vendor-specific manner. 


SAS devices shall only use the parameter fields defined below in Table 385. If any other fields within the Disconnect-Reconnect 
mode page of the MODE SELECT command contain a non-zero value, the device server shall terminate the MODE SELECT 
command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
INVALID FIELD IN PARAMETER LIST. 


Table 385 Disconnect-Reconnect mode page for SAS 

































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (Ob) PAGE CODE (02h) 
1 PAGE LENGTH (0Eh) 
2 Reserved 
3 Reserved 
4 (MSB) 
BUS INACTIVITY TIME LIMIT 
5 (LSB) 
6 
Reserved 
7 
8 (MSB) 
MAXIMUM CONNECT TIME LIMIT 
9 (LSB) 
10 (MSB) 
MAXIMUM BURST SIZE 
11 (LSB) 
12 Restricted 
13 Reserved 
14 (MSB) 
FIRST BURST SIZE 
15 (LSB) 











The PARAMETERS SAVEABLE (PS) bit is defined in 5.3.5. 
The PAGE CODE (PS) field shall be set to 02h. 
The PAGE LENGTH field shall be set to OEh. 
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BUS INACTIVITY TIME LIMIT field 


The value in the BUS INACTIVITY TIME LIMIT field contains the maximum period that an SSP target port is permitted to maintain a connection 
without transferring a frame to the SSP initiator port. This value shall be the number of 100 ms increments between frames that the SSP target 
port transmits during a connection. When this number is exceeded, the SSP target port shall prepare to close the connection (i.e., by request- 
ing to have the link layer transmit DONE). This value may be rounded as defined in 2.3. A value of zero in this field shall specify that there is no 
bus inactivity time limit. 


MAXIMUM CONNECT TIME LIMIT field 


The value in the MAXIMUM CONNECT TIME LIMIT field contains the maximum duration of a connection. This value shall be the number of 100 
ms increments that an SSP target port transmits during a connection after which the SSP target port shall prepare to close the connection (e.g., 
a value of one in this field means that the time is less than or equal to 100 ms and a value of two in this field means that the time is less than or 
equal to 200 ms). If an SSP target port is transferring a frame when the maximum connection time limit is exceeded, the SSP target port shall 
complete transfer of the frame before preparing to close the connection. A value of zero in this field shall specify that there is no maximum 
connection time limit. The maximum connection time limit is enforced by the port layer. This value may be rounded as defined in 2.3. 


MAXIMUM BURST SIZE field 


For read data, the value in the MAXIMUM BURST SIZE field contains the maximum amount of data that is transferred during a connection by an 
SSP target port per |_T_L_Q nexus without transferring at least one frame for a different |_T_L_Q nexus. If the SSP target port: 


a) has read data to transfer for only one |_T_L_Q nexus, and 


b) has no requests to transfer write data for any |_T_L_Q nexus; 


then the SSP target port shall prepare to close the connection after the amount of data specified by the MAXIMUM BURST SIZE field is trans- 
ferred to the SSP initiator port. 


For write data, the value shall specify the maximum amount of data that an SSP target port requests via a single XFER_RDY frame. 


This value shall be specified in 512-byte increments (e.g., a value of one in this field means that the number of bytes transferred to the SSP initi- 
ator port for the nexus is less than or equal to 512 and a value of two in this field means that the number of bytes transferred to the SSP initiator 
port for the nexus is less than or equal to 1 024). The device server may round this value down as defined in 2.3. A value of zero in this field shall 
specify that there is no maximum burst size. 


In terms of the SCSI transport protocol services, the device server shall limit the Request Byte Count argument to the Receive Data-Out () proto- 
col service and the Send Data-In () protocol service to the amount specified in this field. 


FIRST BURST SIZE field 
If the ENABLE FIRST BURST field in the COMMAND frame is set to zero, the FIRST BURST SIZE field is ignored. 


If the ENABLE FIRST BURST field in the COMMAND frame is set to one, the value in the FIRST BURST SIZE field contains the maximum amount of 
write data in 512-byte increments that may be sent by the SSP initiator port to the SSP target port without having to receive an XFER_RDY 
frame from the SSP target port (e.g., a value of one in this field means that the number of bytes transferred by the SSP initiator port is less than 
or equal to 512 and a value of two in this field means that the number of bytes transferred by the SSP initiator port is less than or equal to 
1 024). 


Specifying a non-zero value in the FIRST BURST SIZE field is equivalent to an implicit XFER_RDY frame for each command requiring write data 
where the WRITE DATA LENGTH field of the XFER_RDY frame is set to 512 times the value of the FIRST BURST SIZE field 


The rules for data transferred using the value in the FIRST BURST SIZE field are the same as those used for data transferred for an XFER_RDY 
frame (i.e., the number of bytes transferred using the value in the FIRST BURST SIZE field is as if that number of bytes was requested by an 
XFER_RDY frame). 


If the amount of data to be transferred for the command is less than the amount of data specified by the FIRST BURST SIZE field, the SSP target 
port shall not transmit an XFER_RDY frame for the command. If the amount of data to be transferred for the command is greater than the 
amount of data specified by the FIRST BURST SIZE field, the SSP target port shall transmit an XFER_RDY frame after it has received all of the data 
specified by the FIRST BURST SIZE field from the SSP initiator port. All data for the command is not required to be transferred during the same 
connection in which the command is transferred. 


A value of zero in this field shall specify that there is no first burst size (i.e., an SSP initiator port shall transmit no write DATA frames to the SSP 
target port before receiving an XFER_RDY frame). 
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5.3.16 Format Parameters page (03h) 


This mode page has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


The Format Parameters page implementation is defined in Table 386. This table summarizes the function and defines the default 
or changeability status for each bit. The actual implementation of reserving spare areas for defect management takes place 
during the FORMAT UNIT command. 


Table 386 Format Parameters page (03h) 










































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (0b) PAGE CODE (03h) 
1 PAGE LENGTH (16h) 
2,3 TRACKS PER ZONE 
4,5 ALTERNATE SECTORS PER ZONE 
6,7 ALTERNATE TRACKS PER ZONE 
8,9 ALTERNATE TRACKS PER VOLUME 
10,11 SECTORS PER TRACK 
12,13 DATA BYTES PER PHYSICAL SECTOR 
14,15 INTERLEAVE 
16,17 TRACK SKEW FACTOR 
18,19 CYLINDER SKEW FACTOR 
20 SSEC HSEC RMB SURF DRIVE TYPE 
21,22,23 Reserved 














PS (Page Savable) bit 


The only time this page of parameters may be sent is immediately before sending a FORMAT UNIT command to the drive. The Current parame- 
ters for this page are updated immediately but any changes between these Current parameters and the existing media format are not in effect 
until after the FORMAT UNIT command is completed. A PS bit of 1 indicates this page is savable. The PS bit is not used with the MODE SELECT 
command. 


The PAGE CODE (PS) field shall be set to 03h. 
The PAGE LENGTH field shall be set to 16h. 


TRACKS PER ZONE field 


The TRACKS PER ZONE field indicates the number of tracks the drive allocates to each defect management zone. A zone can be one or more 
tracks or one or more cylinders. See individual drive’s Product Manual, Volume 1, for number of tracks allocated to each defect management 
zone for that drive model. 
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ALTERNATE SECTORS PER ZONE field 

The ALTERNATE SECTORS PER ZONE field indicates the number of spare sectors to be reserved for the defined defect management zone. A 
value of zero indicates that no sectors are to be reserved in each zone for defect management. This is to accommodate hosts that want to man- 
age the defects themselves. 

ALTERNATE TRACKS PER ZONE field 

The ALTERNATE TRACKS PER ZONE field indicates the number of spare tracks to be reserved at the end of each defect management zone. A 
value of zero indicates that no spare tracks are to be reserved in each zone for defect management by the drive. 

ALTERNATE TRACKS PER VOLUME field 


The ALTERNATE TRACKS PER VOLUME field indicates the number of spare tracks to be reserved at the end of the drive volume. The drive uses 
these locations for replacing defective sectors. A value of zero indicates that no spare tracks are to be reserved at the end of the unit for defect 
management. The initiator may change this value for a number between 0 and 255 that is a multiple of the total number of Data Read/Write 
heads installed. However, it is not changeable on some products. 

SECTORS PER TRACK field 


The SECTORS PER TRACK field indicates the average number of physical sectors the drive has per disk track. This value depends on the selected 
sector size and ZBR zones. The number of user accessible sectors per track may be fewer than the reported value, since sectors per Track 
includes sectors set aside for defect management. This value cannot be used to calculate drive user accessible capacity. 

DATA BYTES PER PHYSICAL SECTOR field 

The DATA BYTES PER PHYSICAL SECTOR field indicates the number of data bytes the drive shall allocate per physical sector. This value equals 
the block length reported in the MODE SENSE block descriptor. The bytes per physical sector is not directly changeable by the initiator and is 
not verified on a MODE SELECT command. 

INTERLEAVE field 

The INTERLEAVE field is not supported on Seagate products. 


TRACK SKEW FACTOR field 


The TRACK SKEW FACTOR field indicates the average number of physical sectors between the last logical block on one track and the first logical 
block on the next sequential track of the same cylinder. A value of zero indicates no skew. 


NOTE This value is not changeable by a SCSI initiator port. 


CYLINDER SKEW FACTOR field 


The CYLINDER SKEW FACTOR field indicates the average number of physical sectors between the last logical block of one cylinder and the first 
logical block of the next cylinder. A value of zero indicates no skew. Cylinder skew will be utilized by a drive but is not changeable by a SCSI ini- 
tiator port. 
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SSEC bit set and HSEC bits 


A HSEC bit set to one indicates that the target shall use hard sector formatting. The HSEC bit and the SSEC bit are mutually exclusive in MODE 
SELECT commands. 


Possible combinations of MODE SENSE Report Default Values: 


SSEC HSEC 
0 0 Target shall not return this combination 
1 0 Target supports Soft sector formatting only 
0 1 Target supports Hard sector formatting only 
1 1 Target supports both Soft and Hard sector formatting 


Possible combinations of MODE SENSE Report Changeable Values 


SSEC HSEC 
0 0 Sector formatting Not changeable 
1 0 Target shall not return this combination 
0 1 Target shall not return this combination 
1 1 Target supports both Soft and Hard sector formatting 


RMB (Removable Medium) bit 
0 A removable medium (RMB) bit set to zero indicates that the medium is not removable. 


1 A RMB bit set to one indicates that the medium is removable. 


SURF (Surface) bit 
The SURF (Surface) bit indicates how the target shall map the logical block addressing into physical block addressing. 


O A SURF bit set to zero indicates that the target shall allocate progressive addresses to all sectors within a cylinder prior to allocating sec- 
tor addresses to the next cylinder. 


1 A SURF bit set to one indicates that the target shall allocate progressive addresses to all sectors on a surface prior to allocating sector 
addresses to the next surface. 
DRIVE TYPE field 
The DRIVE TYPE field bits are defined as follows: 


a) The Hard Sectoring (HSEC) bit (bit 6) set to one indicates the drive shall use hard sector formatting. 
b) Bits 0-5, and 7 are not implemented by the drive and are always zero. All bits (0-7) are not changeable. 
c) See individual drive’s Product Manual, Volume 1, MODE SENSE Data clause for changeable values. 
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5.3.17 10 Advice Hints Grouping mode page (OAh/05h) 


The IO Advice Hints Grouping mode page(see table 387) provides the application client with the means to obtain or modify the 
IO advice hints of the logical unit and the group number associated with those IO advice hints. 


The mode page policy (see SPC-5) for this page shall be shared. 
Table 387 10 Advice Hints Grouping mode page 




































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (1b) PAGE CODE (0Ah) 
1 SUBPAGE CODE(05h) 
2 (MSB) 
PAGE LENGTH (40Ch) 
3 (LSB) 
4 
see Reserved 
15 
10 advice hints for group descriptor list 
16 
sae IO advice hints for group descriptor (group 0) 
31 
1024 
se% 10 advice hints for group descriptor (group 63) 
1039 





PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 


The parameters saveable (PS) bit, the subpage format (SPF) bit, the PAGE CODE field, the SUBPAGE CODE field, and the PAGE LENGTH field are 
defined in 5.3.5 and shall be set to the values shown in table 387 for the lO Advice Hints Grouping mode page. 


The format of each IO advice hints group descriptor is shown in table 388. There is one IO advice hints group descriptor for each 
group number. The logical block markup descriptor (see SBC-4) in each IO advice hints group descriptor affects the processing of 
commands as described in 2.2.8. 


Table 388 [lO advice hints group descriptor 
























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 10 ADVICE HINTS MODE Reserved CS_ENABLE | IC_ENABLE 
1 
save Reserved 
3 
4 (MSB) 
LOGICAL BLOCK MARKUP DESCRIPTOR (see SBC-4) 
p-1 (LSB) 
p 
see PAD (if any) 
15 
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10 ADVICE HINTS MODE field 
The IO ADVICE HINTS MODE field specifies the mode of the logical block markup descriptor and is described in table 389. 


Table 389 IO ADVICE HINTS MODE field 














Code Description 

00b The logical block markup descriptor is valid (see 2.2.8). 

01b The logical block markup descriptor is invalid (see 2.2.8). 
Allothers | Reserved 














CS_ENBLE bit 


The cache segment enable (CS_ENBLE) bit specifies whether cache segments (see SBC-4) are associated with the cache ID that is the group 
number associated with this lO advice hints descriptor. If the CS_ENBLE bit is set to zero, then no independent cache segments are associated 
with the cache ID for the group number associated with this |O advice hints descriptor. If the CS_ENBLE bit is set to one, then independent 
cache segments are associated with the cache ID for the group number associated with this l|O advice hints descriptor. 

IC_ENABLE bit 


The information collection enable (IC_ENABLE) bit specifies whether the group's information collection function (see 2.2.8) is enabled. If the 
IC_ENABLE bit is set to zero, then the information collection function is not enabled. If the IC_ENABLE bit is set to one, then the information col- 
lection function is enabled. 


If the Group Statistics and Performance (n) log pages are not supported, then in the IO advice hints group descriptors for group 0 to group 31, 
the IC_ENABLE bit shall be set to zero and shall not be changeable. 


In the IO advice hints group descriptors for group 32 to group 63, the IC_ENABLE bit shall be set to zero, and shall not be changeable. 


LOGICAL BLOCK MARKUP DESCRIPTOR field 
The logical block markup descriptor is described in SBC-4. 
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5.3.18 


Informational Exceptions Control mode page (1Ch) 


Parameters for direct access devices 


The Informational Exceptions Control mode page (see table 390) defines the methods used by the device server to control the 
reporting and the operations of specific informational exception conditions. This page shall only apply to informational 
exceptions that report an additional sense code of FAILURE PREDICTION THRESHOLD EXCEEDED or an additional sense code of 


WARNING to the application client. The mode page policy (see 5.4.14) for this mode page shall be shared, or per |_T nexus. 


Informational exception conditions occur as the result of vendor specific events within a logical unit. An informational exception 


condition may occur asynchronous to any commands issued by an application client. 







































































Table 390 Informational Exceptions Control mode page 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (Ob) PAGE CODE (1Ch) 
1 PAGE LENGTH (0Ah) 
2 PERF Reserved EBF EWASC DEXCPT TEST EBACKERR LOGERR 
3 Reserved MRIE 
4 (MSB) 
seis INTERVAL TIMER 
7 (LSB) 
8 (MSB) 
See REPORT COUNT 
11 (LSB) 














PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field 


The PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field are described in 5.3.5. 


PERF (Performance) bit 


0 
1 


If the performance (PERF) bit is set to zero, informational exception operations that are the cause of delays are acceptable. 


If the PERF bit is set to one, the device server shall not cause delays while doing informational exception operations. A PERF bit set to 
one may cause the device server to disable some or all of the informational exceptions operations, thereby limiting the reporting of 
informational exception conditions. 


EBF (Enable Background Function) bit 
If background functions are supported and the Enable Background Function (EBF) bit is set to one, then the device server shall enable 
background functions. 
If the EBF bit is set to zero, the device server shall disable the functions. Background functions with separate enable control bits (e.g., 


1 


0 


background medium scan defined in 4.3.7 are not controlled by this bit. 


For the purposes of the EBF bit, background functions are defined as idle time functions that may impact performance that are performed by a 
device server operating without errors but do not impact the reliability of the logical unit (e.g., read scan). 
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EWASC (Enable Warning) bit 


0 


If the enable warning (EWASC) bit is set to zero, the device server shall disable reporting of the warning. The MRIE field is ignored when 
DEXCPT is set to one and EWASC is set to zero. 

If the EWASC bit is set to one, warning reporting shall be enabled. The method for reporting the warning when the EWASC bit is set to 
one is determined from the MRIE field. 


DEXCPT (Disable Exception Control) bit 


0 Adisable exception control (DEXCPT) bit set to zero indicates the failure prediction threshold exceeded reporting shall be enabled. The 
method for reporting the failure prediction threshold exceeded when the DEXCPT bit is set to zero is determined from the MRIE field. 

1 A DEXCPT bit set to one indicates the device server shall disable reporting of the failure prediction threshold exceeded. The MRIE field is 
ignored when DEXCPT is set to one and EWASC is set to zero. 

TEST bit 

1 If DEXCPT bit is set to zero and the TEST bit set to one, then the device server shall create a test device failure as specified by the MRIE 
field, INTERVAL TIMER field, and REPORT COUNT field (see table 390). The test device failure shall be reported with the additional sense 
code set to FAILURE PREDICTION THRESHOLD EXCEEDED (FALSE). If both the TEST bit and the DEXCPT bit are set to one, then the MODE 
SELECT command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional 
sense code set to INVALID FIELD IN PARAMETER LIST. 

0 ATEST bit set to zero shall instruct the device server not to generate any test device failure notifications. 


EBACKERR (enable background error) bit 


0 = Anenable background error (EBACKERR) bit set to zero indicates the target shall disable reporting of background self-test errors (SPC-5) 
and background scan errors (see SBC-4). 

1 An EBACKERR bit set to one indicates reporting of background self-test errors and background scan errors shall be enabled. The method 
for reporting background self-test errors and background scan errors is determined by contents of the mrie field. Background self-test 
errors and background scan errors shall be reported as soon as the method specified in the mrie field occurs (i-e., the interval timer field 
and report count field do not apply for background self-test errors and background scan errors). 

LOGERR (Log Error) bit 
0 If the log errors (LOGERR) bit is set to zero, the logging of informational exception conditions by a device server is vendor specific. 
1 If the LOGERR bit is set to one, the device server shall log informational exception conditions. 


MRIE (Method Of Reporting Informational Exceptions) field 


The value in the method of reporting informational exceptions (MRIE) field (see table 390) defines the method that shall be used 
by the device server to report informational exception conditions. The priority of reporting multiple information exceptions is 
vendor specific. 
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Table 391 Method of reporting informational exceptions (MRIE) field 





MRIE Description 











Oh No reporting of informational exception condition: The device server shall not report information exception conditions. 
th Asynchronous event reporting: Obsolete 
2h Generate unit attention: The device server shall report informational exception conditions by establishing a unit attention 


condition (see SAM-5) for the initiator port associated with every I_T nexus, with the additional sense code set to indicate the 
cause of the informational exception condition. 


As defined in SAM-5, the command that has the CHECK CONDITION status with the sense key set to UNIT ATTENTION is not 
processed before the informational exception condition is reported. 


3h Conditionally generate recovered error: The device server shall report informational exception conditions, if the reporting of 


recovered errors is allowed, '@! by returning a CHECK CONDITION status. If the TEST bit is set to zero, the status may be returned 
after the informational exception condition occurs on any command for which GOOD status or INTERMEDIATE status would have 
been returned. If the TEST bit is set to one, the status shall be returned on the next command received on any |_T nexus that is 
normally capable of returning an informational exception condition when the test bit is set to zero. The sense key shall be set to 
RECOVERED ERROR and the additional sense code shall indicate the cause of the informational exception condition. 


The command that returns the CHECK CONDITION for the informational exception shall complete without error before any 
informational exception condition may be reported. 


4h Unconditionally generate recovered error: The device server shall report informational exception conditions, regardless of 


whether the reporting of recovered errors is allowed, {al by returning a CHECK CONDITION status. If the TEST bit is set to zero, the 
status may be returned after the informational exception condition occurs on any command for which GOOD status or 
INTERMEDIATE status would have been returned. If the TEST bit is set to one, the status shall be returned on the next command 
received on any |_T nexus that is normally capable of returning an informational exception condition when the TEST bit is set to 
zero. The sense key shall be set to RECOVERED ERROR and the additional sense code shall indicate the cause of the informational 
exception condition. 


The command that returns the CHECK CONDITION for the informational exception shall complete without error before any 
informational exception condition may be reported. 


5h Generate no sense: The device server shall report informational exception conditions by returning a CHECK CONDITION status. If 
the TEST bit is set to zero, the status may be returned after the informational exception condition occurs on any command for 
which GOOD status or INTERMEDIATE status would have been returned. If the TEST bit is set to one, the status shall be returned on 
the next command received on any I|_T nexus that is normally capable of returning an informational exception condition when 
the TEST bit is set to zero. The sense key shall be set to NO SENSE and the additional sense code shall indicate the cause of the 
informational exception condition. 


The command that returns the CHECK CONDITION for the informational exception shall complete without error before any 
informational exception condition may be reported. 


6h Only report informational exception condition on request: The device server shall preserve the informational exception(s) 
information. To find out about information exception conditions the application client polls the device server by issuing a 
REQUEST SENSE command. In the REQUEST SENSE parameter data that contains the sense data, the sense key shall be set to NO 
SENSE and the additional sense code shall indicate the cause of the informational exception condition. 


7h-Bh Reserved 
Ch - Fh Vendor specific 
{a]_ Error reporting is controlled by the post error (PER) bit in the Read-Write Error Recovery mode page (see 5.3.22). 





























INTERVAL TIMER field 


The INTERVAL TIMER field specifies the period in 100 millisecond increments that the device server shall use for reporting that an informational 
exception condition has occurred (see table 392). After an informational exception condition has been reported, the interval timer shall be 
started. An INTERVAL TIMER field set to zero or FFFF_FFFFh specifies that the period for reporting an informational exception condition is 
vendor specific. 


REPORT COUNT field 


The REPORT COUNT field specifies the maximum number of times the device server may report an informational exception condition to the 
application client. A REPORT COUNT field set to zero specifies that there is no limit on the number of times the device server may report an 
informational exception condition. 
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The device server shall use the values in the INTERVAL TIMER field and the REPORT COUNT field based on the value in the MRIE 
field as shown in table 392. 


Table 392 Use of the INTERVAL TIMER field and the REPORT COUNT field based on the MRIE field 





MRIE 2] Description 





If reporting of an informational exception condition is enabled (see table 391), then the device server shall: 
1) report an informational exception condition when the condition is first detected; and 
2) if the value in the REPORT COUNT field is not equal to one, then: 


1. if the INTERVAL TIMER field is not set to zero or FFFF_FFFFh, then wait the time specified in the INTER- 
VAL TIMER field, and, if that informational exception condition still exists, report the informational 
exception again; and 


2h to 6h 


2. while the informational exception condition exists, continue to report the informational exception con- 
dition after waiting the time specified in the INTERVAL TIMER field until the condition has been reported 
the number of times specified by the REPORT COUNT field. 


The device server may use or may ignore the values in the INTERVAL TIMER field and the REPORT COUNT field to 
report the informational exception condition based on the device specific implementation. 


[a] For values in the MRIE field (see table 390) not shown in this table, the INTERVAL TIMER field and the REPORT COUNT 
field shall be ignored. 





Ch to Fh 























Maintaining the interval timer and the report counter across power cycles, hard resets, logical unit resets, and |_T nexus losses by 
the device server is vendor specific. 
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5.3.19 Logical Block Provisioning mode page (1Ch/02h) 


5.3.19.1. Introduction 


The Logical Block Provisioning mode page (see table 393) specifies the parameters that a device server that supports logical 
block provisioning threshold values (see SBC-4) shall use to report logical block provisioning threshold notifications (see SBC-4). 
The mode page policy (see SPC-5) for this page shall be shared. 


If a method not defined by this standard changes the parameter data to be returned by a device server in the Logical Block 
Provisioning mode page, then the device server shall establish a unit attention condition for the SCSI initiator port associated 
with every I_T nexus with the additional sense code set to MODE PARAMETERS CHANGED. 


Table 393 —_ Logical Block Provisioning mode page 

































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (1b) PAGE CODE (1Ch) 
1 SUBPAGE CODE (02h) 
2 (MSB) 
PAGE LENGTH (n - 3) 
3 (LSB) 
4 Reserved SITUA 
5 
Se Reserved 
15 
Threshold descriptors 
16 
sole Threshold descriptor [first] (see 5.3.19.2) 
23 
1024 
Threshold descriptor [last] (see 5.3.19.2) 
n 














PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field 

The parameters saveable (PS) bit, the subpage format (SPF) bit, the PAGE CODE field, the SUBPAGE CODE field, and the PAGE LENGTH field are 
defined in SPC-5 and shall be set to the values shown in table 393 for the Logical Block Provisioning mode page. 

SITUA bit 


1 specifies that the logical block provisioning threshold notification unit attention condition is established on a single |_T nexus as 
described in SBC-4. 


0 _ specifies that the logical block provisioning threshold notification unit attention condition is established on multiple |_T nexuses as 
described in SBC-4. 


Threshold descriptors fields 
The threshold descriptors are defined in 5.3.19.2. 
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5.3.19.2 Threshold descriptor format 
The threshold descriptor format is defined in table 394. 


Table 394 Threshold descriptor format 

































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 ENABLED Reserved THRESHOLD TYPE THRESHOLD ARMING 

1 THRESHOLD RESOURCE 

2 

3 Reserved 

4 (MSB) 

THRESHOLD COUNT 

n (LSB) 

ENABLED bit 


1 an ENABLED bit set to one specifies that the threshold is enabled. 
QO = an ENABLED bit set to zero specifies that the threshold is disabled. 


THRESHOLD TYPE field 
The THRESHOLD TYPE field (see table 395) specifies the type of this threshold. 


Table 395 THRESHOLD TYPE field 





Code Description 





000b If the THRESHOLD COUNT field specifies a soft threshold, the threshold is enabled, and that threshold is 
reached, then the device server shall establish a unit attention condition as described in SBC-4. 





001b If the THRESHOLD COUNT field specifies a percentage threshold, the threshold is enabled, and that threshold 
is reached, then the device server shall establish a unit attention condition as described in SBC-4. 





Allothers | Reserved 
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THRESHOLD ARMING field 
The THRESHOLD ARMING field (see table 396) specifies the arming method used for operation of this threshold. 


Table 396 THRESHOLD ARMING field 





Code Description Reference 





000b The threshold operates as an armed decreasing threshold. SBC-4 





001b The threshold operates as an armed increasing threshold. SBC-4 

















Allothers | Reserved 





THRESHOLD RESOURCE field 


The THRESHOLD RESOURCE field specifies the resource of this threshold. The contents of this field are as defined for parameters codes 0000h to 
OOFFh in the Logical Block Provisioning log page (see 5.2.13). 


The valid combinations of the THRESHOLD TYPE field, the THRESHOLD ARMING field, and the THRESHOLD RESOURCE field are shown in SBC-4. 


THRESHOLD COUNT field 
The THRESHOLD COUNT field specifies the center of the threshold range for this threshold expressed as: 


a) anumber of threshold sets (i.e., the number of LBA mapping resources expressed as a number of threshold sets), if the value in the 
THRESHOLD TYPE field is set to 000b; or 


b) apercentage value, if the value in the THRESHOLD TYPE field is set to 001b. 
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5.3.20 


Power Condition mode page (1Ah) 


Parameters for direct access devices 


The Power Condition mode page provides an application client with methods to control the power condition of a logical unit 
(see SPC-5). These methods include: 


a) Specifying that the logical unit transition to a power condition without delay; and 


b) Activating and setting of idle condition and standby condition timers to specify that the logical unit wait for a period of 
inactivity before transitioning to a specified power condition. 


The mode page policy (see 3.9) for this mode page shall be shared. 


When a device server receives a command while in a power condition based ona setting in the Power Condition mode page, the 
logical unit shall transition to the power condition that allows the command to be processed. If either the idle condition timer or 
the standby condition timer has been set, then they shall be reset on receipt of the command. On completion of the command, 
the timer(s) shall be started. 


Logical units that contain cache memory shall write all cached data to the medium for the logical unit (e.g.,as a logical unit does 
in response to a SYNCHRONIZE CACHE command as described in 3.51 and 3.52) prior to entering into any power condition that 
prevents accessing the media (e.g., before a hard drive stops its spindle motor during transition to the standby power condition). 


The logical unit shall use the values in the Power Condition mode page to control its power condition after a power on or a hard 
reset until a START STOP UNIT command setting a power condition is received. 


Table 397 defines the Power Condition mode page. 








































































































Table 397 Power Condition mode page 
Bit 7 6 4 3 2 1 0 
Byte 
0 PS SPF (0b) PAGE CODE (1Ah) 
1 PAGE LENGTH (26h) 
2 PM_BG_PRECEDENCE Reserved STANDBY_Y 
3 Reserved IDLE_C IDLE_B IDLE_A STANDBY_Z 
4 (MSB) 
eee IDLE_A CONDITION TIMER 
7 (LSB) 
8 (MSB) 
ees STANDBY_Z CONDITION TIMER 
11 (LSB) 
12 (MSB) 
Sar IDLE_B CONDITION TIMER 
15 (LSB) 
16 (MSB) 
ser IDLE_C CONDITION TIMER 
19 (LSB) 
20 (MSB) 
sae STANDBY_Y CONDITION TIMER 
23 (LSB) 
24 
rer Reserved 
38 
39 CCF_IDLE CCF_STANDBY CCF_STOPPED Reserved 








PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field 
The PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field are described in 5.3.5. 
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PM_BG_PRECEDENCE field 
The PM_BG_PRECEDENCE field (see table 398) specifies the interactions between background functions (see SPC-5) and power management. 


The behavior of the idle and standby condition timers controlled by this mode page is defined in the power condition overview 
and the power condition state machine (see SPC-5). 


Table 398 PM_BG_ PRECEDENCE field 

















Code Description 
00b Vendor specific 
Performing background functions take precedence over maintaining low power conditions as follows: 
a) if the logical unit is in a low power condition as the result of a power condition timer associated with that condition expiring, 
then: 
1) the logical unit shall change from that power condition, if necessary, to the power condition required to perform the back- 
ground function, when: 
a) a timer associated with a background scan operation expires, and that function is enabled (see SBC-4); 
or 
b) an event occurs to initiate a device specific background function, and that function is enabled (see SPC-5); 
2) the logical unit shall perform the background function(s) based on the definitions in this standard and other command stan- 
01b dards (e.g., if the device server receives acommand while performing a background function, then the logical unit shall sus- 
pend the function to process the command); 
3) if more than one condition is met to initiate a background function, then: 
a) all initiated background functions shall be performed; and 
b) the order of performing the functions is vendor specific; and 
4) when all initiated background functions have been completed, the device server shall check to see if any power condition 
timers have expired. If any power condition timer has expired, then the logical unit shall change to the power condition 
associated with the highest priority timer that has expired; 
or 
b) if the logical unit is performing a background function, and a power condition timer expires, then the logical unit shall perform 
all initiated background functions before the logical unit changes to a power condition associated with a timer has expired. 
Maintaining low power conditions take precedence over performing background functions as follows: 
a) if the logical unit is in a low power condition, then the logical unit shall not change from that power condition to perform a 
background function; 
b) the device server may perform any initiated and enabled background function based on the definitions in this standard or 
other command standards, if all of the following are true: 
A) a condition is met to initiate a background function; 
B) that background function is enabled; 
10b C) the logical unit changes to a power condition in which the background function may be performed (e.g., the device server 
processes a medium access command causing the logical unit to change its power condition to continue processing that 
command); and 
D) all outstanding application client requests have been completed; 
or 
c) if the logical unit is performing a background function, and a power condition timer expires that causes a change to a power 
condition in which the logical unit is unable to continue performing the background function, then the logical unit shall: 
A) suspend the background function; and 
B) change to the power condition associated with the timer that expired. 
11b Reserved 
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STANDBY_Y bit 
1 If the STANDBY_Y bit is set to one, then the standby_y condition timer is enabled. 
0 If the STANDBY_Y bit is set to zero, then the device server shall ignore the standby_y condition timer. 


IDLE_C bit 
1 If the IDLE_C bit is set to one, then the idle_c condition timer is enabled. 


0 If the IDLE_C bit is set to zero, then the device server shall ignore the idle_c condition timer. 


IDLE_B bit 
1 If the IDLE_B bit is set to one, then the idle_b condition timer is enabled. 


0 If the IDLE_B bit is set to zero, then the device server shall ignore the idle_b condition timer. 


IDLE_A bit 
1 If the IDLE_A bit is set to one, then the idle_a condition timer is enabled. 


0 If the IDLE_A bit is set to zero, then the device server shall ignore the idle_a condition timer. 


STANDBY _Z bit 
1 If the STANDBY_Z bit is set to one, then the standby_z condition timer is enabled. 
0 If the STANDBY_Z bit is set to zero, then the device server shall ignore the standby_z condition timer. 


If any of the power condition enable bits (e.g., the IDLE_C bit or the STANDBY_Y bit) are set to zero and are not changeable (see 
3.11.1.2), then the device server does not implement the power condition timer associated with that enable bit (see SPC-5). 


IDLE_A CONDITION TIMER field 


The IDLE_A CONDITION TIMER field specifies the initial value, in 100 millisecond increments, for the idle_a power condition timer (see SPC-5). 
This value may be rounded up or down to the nearest implemented time as described in 2.3. 


STANDBY_Z CONDITION TIMER field 


The STANDBY_Z CONDITION TIMER Timer field specifies the initial value, in 100 millisecond increments, for the standby_z power condition 
timer (see SPC-5). This value may be rounded up or down to the nearest implemented time as described in 2.3. 


IDLE_B CONDITION TIMER field 

The IDLE_B CONDITION TIMER field specifies the initial value, in 100 millisecond increments, for the idle_b power condition timer (see SPC-5). 
This value may be rounded up or down to the nearest implemented time as described in 2.3. 

IDLE_C CONDITION TIMER field 

The IDLE_C CONDITION TIMER field specifies the initial value, in 100 millisecond increments, for the idle_c power condition timer (see SPC-5). 
This value may be rounded up or down to the nearest implemented time as described in 2.3. 


STANDBY_Y CONDITION TIMER field 


The STANDBY_Y CONDITION TIMER field specifies the initial value, in 100 millisecond increments, for the standby_y power condition timer (see 
SPC-5). This value may be rounded up or down to the nearest implemented time as described in 2.3. 
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CCF_IDLE field 
The Check Condition From idle_c processing control (CCF_IDLE) field is defined in Table 399. 


Table 399 CCF_IDLE field 











Code 

00b Restricted /! 

O1b If the transition was from an idle_c power condition, returning CHECK CONDITION status is disabled. [b] 
10b If the transition was from an idle_c power condition, returning CHECK CONDITION status is enabled. [b] 
11b Reserved 





[a] See SAS-3 for command processing in the Active_Wait state and Idle_Wait state. 
[b] For direct-access block devices see the Active_Wait state in SBC-4 for the definition of command processing in that state. 
For devices that are not direct-access block devices, see the state in (SPC-5) for the definition of command processing in 





that state. 








CCF_STANDBY field 
The CHECK CONDITION From Standby (CCF_STANDBY) field is defined in Table 400. 


Table 400 CCF_STANDBY field 





Code 

00b Restricted 1 

01b If transition was from a standby power condition, returning CHECK CONDITION status is disabled. [b] 
10b If transition was from a standby power condition, returning CHECK CONDITION status is enabled. [b] 
11b Reserved 








[a] See SAS-3 for command processing in the Active_Wait state and Idle_Wait state. 
[b] For direct-access block devices see the Active_Wait state in SBC-4 for the definition of command processing in that state. 
For devices that are not direct-access block devices, see the state in (SPC-5) for the definition of command processing in 











that state. 


CCF_STOPPED field 
The CHECK CONDITION if from stopped (CCF_STOPPED) field is defined in Table 401. 


Table 401 CCF_STOPPED field 








Code 

00b Restricted 1 

01b If the transition was from a standby power condition, returning CHECK CONDITION is disabled. {b] 
10b If the transition was from a standby power condition, returning CHECK CONDITION is enabled. [b] 
11b Reserved 








[a] See SAS-3 for command processing in the Active_Wait state and Idle_Wait state. 
[b] For direct-access block devices see the Active_Wait state in SBC-4 for the definition of command processing in that state. 
For devices that are not direct-access block devices, see the state in (SPC-5) for the definition of command processing in 











that state. 
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5.3.21 


Power Consumption Mode page (1Ah/01h) 


The Power Consumption mode page (see table 402) provides a method to set the power consumption level while in the active 
power condition (see SPC-5) to: 


a) arelative power consumption level (see SPC-5); or 
b) amaximum power consumption level (see SPC-5) that is based on the contents of the power consumption descriptors in the Power 
Consumption VPD page (see 5.4.16)). 


The mode page policy (see 5.4.14) for this mode page shall be shared. 


Parameters for direct access devices 






























































Table 402 Power Consumption mode page 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (1b) PAGE CODE (1Ah) 
1 SUBPAGE CODE (01h) 
2 (MSB) 
PAGE LENGTH (000Ch) 
3 (LSB) 
4 
Reserved 
5 
6 Reserved ACTIVE LEVEL 
7 POWER CONSUMPTION IDENTIFIER 
8 
nee Reserved 
15 














PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field and PAGE LENGTH field 
The PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field and PAGE LENGTH field are described in 5.2.2 and shall be set as shown in table 402 
for the Power Consumption mode page. 
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ACTIVE LEVEL field 


The ACTIVE LEVEL field (see table 403) specifies the relative active power consumption level, in any. 


Table 403 ACTIVE LEVEL field 




















Code Description 

00b The active power consumption level is specified by the POWER CONSUMPTION IDENTIFIER field. 
O01b Highest relative active power consumption level 

10b Intermediate relative active power consumption level 

11b Lowest relative active power consumption level 











If the application client specifies an unsupported value for the ACTIVE LEVEL field, the device server shall terminate the MODE SELECT com- 
mand with CHECK CONDITION status, with the sense key set to ILLEGALREQUEST, and the additional sense code set to INVALID FIELD IN 
PARAMETER LIST. 


n If the ACTIVE LEVEL field is set to a non-zero value, the POWER CONSUMPTION IDENTIFIER field is ignored. 


0 If the ACTIVE LEVEL field is set to zero, the POWER CONSUMPTION IDENTIFIER field specifies the power consumption identifier from one 


of the power consumption descriptors in the Power Consumption VPD page (see 5.4.16) that the device server is to use as described in 
SPC-5. 


If the application client specifies an ACTIVE LEVEL field set to zero and a value for the POWER CONSUMPTIONIDENTIFIER field that is not con- 
tained in a power consumption descriptor in the Power Consumption VPD page, then the device server shall terminate the MODE SELECT com- 
mand with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD 
INPARAMETER LIST. 
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Read-Write Error Recovery mode page (01h) 


The Read-Write Error Recovery mode page (see table 404) specifies the error recovery parameters the device server shall use 
during any command that performs a read or write operation to the medium (e.g., READ commands, WRITE commands, and 
WRITE AND VERIFY commands). 






















































































Table 404 Read-Write Error Recovery mode page 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (Ob) PAGE CODE (01h) 
1 PAGE LENGTH (0Ah) 
> AWRE ARRE 7B RC ERROR RECOVERY BITS 
EER PER DTE DCR 
3 READ RETRY COUNT 
4 Obsolete 
5 Obsolete 
6 Obsolete 
7 Reserved Ps Se 
8 WRITE RETRY COUNT 
9 Reserved 
10 (MSB) 
1 RECOVERY TIME LIMIT (LB) 
PS (Parameters Savable) bit 


The parameters savable (PS) bit is only used with the MODE SENSE command. This bit is reserved with the MODE SELECT command. A PS bit set 


to one 


indicates that the device server is capable of saving the mode page in a non-volatile vendor-specific location. 


PAGE CODE field and PAGE LENGTH field 


The PAGE CODE field and PAGE LENGTH field are described in 5.3.5. 


AWRE 
0 


(Automatic Write Reallocation Enabled) bit 


An automatic write reallocation enabled (AWRE) bit set to zero specifies that the device server shall not perform automatic reallocation 
of defective logical blocks during write operations. 


An AWRE bit set to one specifies that the device server shall enable automatic reallocation of defective logical blocks during write oper- 
ations. The automatic reallocation shall be performed only if the device server has the valid data (e.g., original data in a buffer or recov- 
ered from the medium). The valid data shall be placed in the reallocated logical block. The device server shall report any failures that 
occur during the reallocation operation. Error reporting as specified by the error recovery bits (i.e., the EER bit, the PER bit, the DTE bit, 
and the DCR bit) shall be performed only after completion of the reallocation. See the REASSIGN BLOCKS command (see 3.28) for error 
procedures. 


ARRE (Automatic Read Reallocation Enabled) bit 


0 
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An automatic read reallocation enabled (ARRE) bit set to zero specifies that the device server shall not perform automatic reallocation of 
defective logical blocks during read operations. 
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TB (Transfer Block) bit 


0 Atransfer block (TB) bit set to zero specifies that the device server shall not transfer a logical block to the data-in buffer if the logical 
block is not recovered within the recovery limits specified. 


1 A TB bit set to one specifies that the device server shall transfer a logical block to the data-in buffer before returning CHECK CONDITION 
status if the logical block is not recovered within the recovery limits specified. The data returned in this case is vendor-specific. The TB bit 
does not affect the action taken for recovered data. 

RC (Read Continuous) bit 


0 Aread continuous (RC) bit set to zero specifies that error recovery operations that cause delays are acceptable during the data transfer. 
Data shall not be fabricated. 


1 An RC bit set to one specifies the device server shall transfer the entire requested length of data without adding delays to perform error 
recovery procedures. This implies that the device server may send data that is erroneous or fabricated in order to maintain a continuous 
flow of data. The device server shall assign priority to the RC bit over conflicting bits within this byte. 


NOTE Fabricated data may be data already in a buffer or any other vendor-specific data. The RC bit may be 
used in image processing, audio, or video applications. 


EER (Enable Early Recovery) bit 
1 An enable early recovery (EER) bit set to one specifies that the device server shall use the most expedient form of error recovery first. 


0 An EER bit set to zero specifies that the device server shall use an error recovery procedure that minimizes the risk of error mis-detection 
or mis-correction. This bit only applies to data error recovery and it does not affect positioning retries. 


PER (Post Error) bit 


1 A post error (PER) bit set to one specifies that if a recovered read error occurs during a command performing a read or write operation, 
then the device server shall terminate the command with CHECK CONDITION status with the sense key set to RECOVERED ERROR. If the 
DTE bit is set to one, then the PER bit shall be set to one 


OA PER bit set to zero specifies that if a recovered read error occurs during a command performing a read or write operation, then the 
device server shall perform error recovery procedures within the limits established by the error recovery parameters and only terminate 
the command with CHECK CONDITION status if the error becomes uncorrectable based on the established limits. 

DTE (Data Terminate On Error) bit 


1 A data terminate on error (DTE) bit set to one specifies that the device server shall terminate the data-in or data-out buffer transfer upon 
detection of a recovered error. 


0 = ADTE bit set to zero specifies that the device server shall not terminate the data-in or data-out buffer transfer upon detection of a recov- 
ered error. 
DCR (Disable Correction) bit 
1 A disable correction (DCR) bit set to one specifies that ECC shall not be used for data error recovery. 


0 A DCR bit set to zero allows the use of ECC for data error recovery. If the EER bit is set to one, the DCR bit shall be set to zero. 


SCSI Commands Reference Manual, Rev. J 429 


www.seagate.com 


Parameters for direct access devices 


The combinations of the error recovery bits (i.e., the EER bit, the PER bit, the DTE bit, and the DCR bit) are explained in table 405. 


Table 405 


Combined error recovery bit descriptions (Sheet 1 of 3) 





EER | PER 


DTE 


DCR 


Description 





0 0 


0 


0 


The device server shall perform the full number of retries as specified in the READ RETRY COUNT field for read 
operations, the WRITE RETRY COUNT field for write operations, and the VERIFY RETRY COUNT field (see 5.3.35) for 
verify operations and shall perform error correction in an attempt to recover the data. 


The device server shall not report recovered errors. The device server shall terminate a command with CHECK 
CONDITION status before the transfer count is exhausted only if an unrecoverable error is detected. 


If an unrecoverable data error occurs during a read operation, the data in the block with the unrecoverable error 
may or may not be transferred to the data-in buffer depending on the setting of the transfer block (TB) bit. 





The device server shall perform the full number of retries as specified in the READ RETRY COUNT field for read 
operations, the WRITE RETRY COUNT field for write operations, and the VERIFY RETRY COUNT field (see 5.3.35) for 
verify operations but shall not perform error correction in an attempt to recover the data. 


The device server shall not report recovered errors. The device server shall terminate a command with CHECK 
CONDITION status before the transfer count is exhausted only if an unrecoverable error is detected. 


If an unrecoverable data error occurs during a read operation, the data in the block with the unrecoverable error 
may or may not be transferred to the data-in buffer depending on the setting of the transfer block (TB) bit. 





Invalid mode. The PER bit shall be set to one if the DTE bit is set to one! 

















Invalid mode. The PER bit shall be set to one if the DTE bit is set to one! 


The device server shall perform the full number of retries as specified in the READ RETRY COUNT field for read 
operations, the WRITE RETRY COUNT field for write operations, and the VERIFY RETRY COUNT field (see 5.3.35) for 
verify operations and shall perform error correction in an attempt to recover the data. 


The device server shall terminate a command with CHECK CONDITION status before the transfer count is 
exhausted only if an unrecoverable error is detected. 


If an unrecovered read error occurs during a read operation, the transfer block (TB) bit determines whether the 
data for the logical block with the unrecovered read error is transferred to the data-in buffer. 


If a recovered error occurs while the device server is performing a read or write operation, then, after the 
operation is complete, the device server shall terminate the command with CHECK CONDITION status with the 
sense key set to RECOVERED ERROR. The INFORMATIO field in the sense data shall contain the LBA of the last 
recovered error that occurred during the command. 


The device server shall perform the full number of retries as specified in the READ RETRY COUNT field for read 
operations, the WRITE RETRY COUNT field for write operations, and the VERIFY RETRY COUNT field (see 5.3.35) for 
verify operations but shall not perform error correction in an attempt to recover the data. 


The device server shall terminate a command performing a read or write operation with CHECK CONDITION status 
before the transfer count is exhausted only if an unrecoverable error is detected. 


If an unrecovered read error occurs during a read operation, the transfer block (TB) bit determines whether the 
data for the logical block with the unrecovered read error is transferred to the data-in buffer. 


If a recovered error occurs while the device server is performing a read or write operation, then, after the 
operation is complete, the device server shall terminate the command with CHECK CONDITION status with the 
sense key set to RECOVERED ERROR. The INFORMATION field in the sense data shall contain the LBA of the last 





recovered error that occurred during the command. 
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Table 405 Combined error recovery bit descriptions (Sheet 2 of 3) 
EER | PER | DTE | DCR |Description 

0 1 1 0 ‘|The device server shall perform the full number of retries as specified in the READ RETRY COUNT field for read 
operations, the WRITE RETRY COUNT field for write operations, and the VERIFY RETRY COUNT field (see 5.3.35) for 
verify operations and shall perform error correction in an attempt to recover the data. 

The device server shall terminate a command performing a read or write operation with CHECK CONDITION status 
before the transfer count is exhausted if any error, either recoverable or unrecoverable, is detected. The 
INFORMATION field in the sense data shall contain the LBA of the block in error. 

If an unrecoverable data error occurs during a read operation, the transfer block (TB) bit determines whether the 
data for the logical block with the unrecovered read error is transferred to the data-in buffer. 

0 1 1 1 |The device server shall perform the full number of retries as specified in the READ RETRY COUNT field for read 
operations, the WRITE RETRY COUNT field for write operations, and the VERIFY RETRY COUNT field (see 5.3.35) for 
verify operations but shall not perform error correction in an attempt to recover the data. 

The device server shall terminate a command performing a read or write operation with CHECK CONDITION status 
before the transfer count is exhausted if any error, either recoverable or unrecoverable, is detected. The 
INFORMATION field in the sense data shall contain the LBA of the block in error. 

If an unrecoverable data error occurs during a read operation, the transfer block (TB) bit determines whether the 
data for the logical block with the unrecovered read error is transferred to the data-in buffer. 

1 0 0 0 |The device server shall perform the fewest possible number of retries and perform error correction in an attempt 
to recover the data. 

The device server shall not report recovered errors. The device server shall terminate a command performing a 
read or write operation with CHECK CONDITION status before the transfer count is exhausted only if an 
unrecoverable error is detected. 

If an unrecoverable data error occurs during a read operation, the transfer block (TB) bit determines whether the 
data for the logical block with the unrecovered read error is transferred to the data-in buffer. 

] 0 0 1 |Invalid mode. The DCR bit shall be set to zero if the EER bit is set to one! 
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Table 405 Combined error recovery bit descriptions (Sheet 3 of 3) 





EER | PER | DTE | DCR |Description 





1 1 0 0 |The device server shall perform the fewest possible number of retries and perform error correction in an attempt 
to recover the data. 


The device server shall terminate a command performing a read or write operation with CHECK CONDITION status 
before the transfer count is exhausted only if an unrecoverable error is detected. 


If an unrecoverable data error occurs during a read operation, the transfer block (TB) bit determines whether the 
data for the logical block with the unrecovered read error is transferred to the data-in buffer 


If a recovered error occurs while the device server is performing a read or write operation, then, after the 
operation is complete, the device server shall terminate the command with CHECK CONDITION status with the 
sense key set to RECOVERED ERROR. The INFORMATION field in the sense data shall contain the LBA of the last 
recovered error that occurred during the command. 





1 ] 0 1 |Invalid mode. The DCR bit shall be set to zero if the EER bit is set to one! 





1 1 1 0 ‘|The device server shall perform the fewest possible number of retries and perform error correction in an attempt 
to recover the data. 


The device server shall terminate the command performing a read or write operation with CHECK CONDITION 
status before the transfer count is exhausted if any error, either recoverable or unrecoverable, is detected. The 
INFORMATION field in the sense data shall contain the LBA of the block in error. 


If an unrecoverable data error occurs during a read operation, the transfer block (TB) bit determines whether the 
data for the logical block with the unrecovered read error is transferred to the data-in buffer. 





1 ] ] 1 |Invalid mode. The DCR bit shall be set to zero if the EER bit is set to one! 

















[a]lf an invalid combination of the error recovery bits is sent by the application client the device server shall terminate the MODE 
SELECT command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
INVALID FIELD IN PARAMETER LIST. 











READ RETRY COUNT field 
The READ RETRY COUNT field specifies the number of times that the device server shall attempt its recovery algorithm during read operations. 


WRITE RETRY COUNT field 


The WRITE RETRY COUNT field specifies the number of times that the device server shall attempt its recovery algorithm during write opera- 
tions. 


RECOVERY TIME LIMIT field 


The RECOVERY TIME LIMIT field specifies in milliseconds the maximum time duration that the device server shall use for data error recovery 
procedures. The device server may round this value as described in 2.3. The limit in this field specifies the maximum error recovery time 
allowed for any individual command. A RECOVERY TIME LIMIT field set to zero specifies that the device server shall use its default value. 


When both a retry count and a recovery time limit are specified, the field that specifies the recovery action of least duration shall 
have priority. 


To disable all types of correction and retries the application client should set the EER bit to zero, the PER bit to one, the DTE bit to 
one, the DCR bit to one, the READ RETRY COUNT field to 00h, the WRITE RETRY COUNT field to 00h, and the RECOVERY TIME 
LIMIT field to 0000h. 
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5.3.23 Logical Unit Control mode page (18h) for FC 


The Fibre Channel Logical Unit Control mode page (see table 406) contains those parameters that select FCP logical unit 
operation options. The implementation of any parameter and its associated functions is optional. The mode page follows the 
MODE SENSE and MODE SELECT command rules. 


Table 406 __‘ Fibre Channel Logical Unit Control mode page (18h) 



























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PS SPF (Ob) PAGE CODE (18h) 

1 PAGE LENGTH (06h) 

2 Reserved PROTOCOL IDENTIFIER (FCP = Oh) 

3 Reserved EPDC 

4 Reserved 

5 Reserved 

6 Reserved 

7 Reserved 











PS bit, SPF bit, PAGE CODE field and PAGE LENGTH field 
The PS bit, SPF bit, PAGE CODE field and PAGE LENGTH field are described in 5.2.2. 


PROTOCOL IDENTIFIER field 


The value in the PROTOCOL IDENTIFIER (see table 406) field defines the SCSI transport protocol to which the mode page applies. For a MODE 
SENSE command (see 3.11), the device server shall set the PROTOCOL IDENTIFIER field to one of the values shown in Clause 5.3.23 to indicate 
the SCSI transport protocol used by the target port through which the MODE SENSE command is being processed. For a MODE SELECT com- 
mand (see 3.9), the application client shall set the PROTOCOL IDENTIFIER field to one of the values shown in Table 406 indicating the SCSI trans- 
port protocol to which the PROTOCOL SPECIFIC MODE PARAMETERS apply. If a device server receives a mode page containing a transport 
protocol identifier value other than the one used by the target port on which the MODE SELECT command was received, then the command 
shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID 
FIELD IN PARAMETER LIST. 


EPDC (ENABLE PRECISE DELIVERY CHECKING) bit 


1 An ENABLE PRECISE DELIVERY CHECKING (EPDC) bit of one indicates that the logical unit shall use the precise delivery function (see 
FCP-4). 

0 When the EPDC bit is set to zero, the logical unit shall not use the precise delivery function and shall ignore the contents of the CRN field 
in the FCP_CMND IU. 


The EPDC bit is valid for all types of link connections. If the precise delivery function is not supported and the Fibre Channel Logical Unit Con- 
trol mode page is supported by the logical unit, the EPDC bit shall be masked as not changeable and shall follow the MODE SENSE and MODE 
SELECT command rules (see 3.9). 
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5.3.24 Logical Unit mode page (18h) for SAS 


The SAS Protocol-Specific Logical Unit mode page (see SPL-2) contains parameters that affect SSP target port operation on 
behalf of the logical unit. 


The mode page policy (see 5.4.14) for the Protocol-Specific Logical Unit mode page short format subpage shall be either shared 
or per target port. If a SAS target device has multiple SSP target ports, the mode page policy should be per target port. 
Parameters in this page shall affect all phys in the SSP target port if the mode page policy is per target port, and shall affect all 
SSP target ports in the SAS target device if the mode page policy is shared. 


Table 407 defines the format of the page for SAS. 


Table 407 _— Protocol-Specific Logical Unit mode page for SAS 
























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (0b) PAGE CODE (18h) 
1 PAGE LENGTH (06h) 
TRANSPORT 
2 Reserved LAYER RETRIES PROTOCOL IDENTIFIER (6h) 
3 Reserved 
‘ Reserved 
7 
PS bit 


The PARAMETERS SAVEABLE (PS) bit is defined in 5.3.5. 


SPF bit 


The SPF bit shall be set to zero for access to the short format mode page. 


PAGE CODE field 
The PAGE CODE field shall be set to 18h. 


PAGE LENGTH field 
The PAGE LENGTH field shall be set to 06h. 


PROTOCOL IDENTIFIER field 
The PROTOCOL IDENTIFIER field shall be set to 6h indicating this is a SAS specific mode page. 


TRANSPORT LAYER RETRIES bit 


1 A TRANSPORT LAYER RETRIES bit set to one specifies that the target port shall support transport layer retries for XFER_RDY and DATA 
frames for the logical unit as described in SAS-3 Transport Layer. 


O  ATRANSPORT LAYER RETRIES bit set to zero specifies that transport layer retries shall not be used. 
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5.3.25 Port Control Mode page (19h) for FC 


The Fibre Channel Interface Control page controls options relevant to Fibre Channel protocol. It is intended for the control of 
features unique to Fibre Channel protocol that are not suitable for control by login or other techniques defined for Fibre 
Channel. 


Both the current and saved values of Mode page 19h, byte 3, are changeable using the Mode Select command. When the saved 
value of Byte 3 is changed, a new value is stored in nonvolatile (flash) memory, not on disk, and is reported during a Mode Sense 
command when either the current or saved value is requested. 


The current value of Byte 3 may be modified using Mode Select command any number of times. The saved value of Byte 3 may 
be modified using the Mode Select command up to 32 times. After 32 modifications, additional attempts to modify will result in 
a response of Illegal Request (05) with Error Code of 2600 (Invalid field in parameter list) and the Sense Key pointing to byte 3 as 
the offending parameter. Additional updates of Byte 3 saved value may be accomplished by downloading new microcode that 
supports Fibre Channel Interface Control page 19h. After a download, the saved value of Byte 3 may be updated 31 more times 
or 32 times if the value is 0 at the time of download. 


The saved and current value of Byte 3 is preserved through the download. 


Table 408 _‘ Fibre Channel Interface Control page (19h) 













































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PS SPF (0b) PAGE CODE (19h) 

1 PAGE LENGTH (06h) 

2 Reserved PROTOCOL IDENTIFIER (FCP = 0h) 

3 DTFD PLPB DDIS DLM RHA ALWLI DTIPE DTOLI 

4 Reserved 

5 Reserved 

6 Reserved 

7 SEQUENCE INITIATIVE RESOURCE RECOVERY TIMEOUT VALUE (RR_TOVSEQ_ INIT) 











PS (Parameter Savable) 
The PS bit is defined in 5.3.5. 


SPF bit 


The SPF bit shall be set to zero for access to the short format mode page. 


PAGE CODE field 
The PAGE CODE field is described in 5.2.2. 


Page Length byte 


The length of the Fibre Channel Interface Control page in bytes (06h). If the allocation length is too small to transfer all of the page, the page 
length is not adjusted to reflect the truncation. 
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PROTOCOL IDENTIFIER field 


The value in the PROTOCOL IDENTIFIER field defines the SCSI transport protocol to which the mode page applies. For a MODE SENSE command 
(see 3.11), the device server shall set the PROTOCOL IDENTIFIER field to one of the values shown in Clause 5.3.23 to indicate the SCSI transport 
protocol used by the target port through which the MODE SENSE command is being processed. For a MODE SELECT command (see 3.9), the 
application client shall set the PROTOCOL IDENTIFIER field to one of the values shown in Table 408 indicating the SCSI transport protocol to 
which the PROTOCOL SPECIFIC MODE PARAMETERS apply. If a device server receives a mode page containing a transport protocol identifier 
value other than the one used by the target port on which the MODE SELECT command was received, then the command shall be terminated 
with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER 
LIST. 


DTFD (Disable Target Fabric Discovery) 


1 The target attached by an FC-AL loop will not recognize the presence of a fabric loop port (FL_Port) on the loop. The target will only per- 
form the private loop functions defined for FC-PLDA targets. 


0 ‘The target attached by an FC-AL loop will discover the FL_Port if present on the loop and will perform the public loop functions defined 
for FC-FLA targets. Targets attached to an N_Port or to an F_Port will ignore this bit. 


PLPB (Prevent Loop Port Bypass) 
1 The target ignores any Loop Port Bypass (LPB) and Loop Port Enable (LPE) primitive sequences. The loop port remains enabled. 


Note. Do not set the PLPB bit to one (1) and the DTIPE bit to one (1) at the same time as this is an illegal bit combination. When an illegal bit 
combination is sent by the application client, the device server returns Check Condition status and sets the sense key to Illegal Request 
with the additional sense code set to Invalid Field in the Parameter List. 


0 ‘The target allows the Loop Port Bypass and Port Bypass Enable primitive sequences to control the port bypass circuit. 


DDIS (Disable Discovery) 


1 The target does not require receipt of Address or Port Discovery ELS following loop initialization. The target resumes processing of tasks 
upon completion of loop initialization. 


0 ‘The target must wait to receive an Address or Port Discovery ELS before it resumes processing tasks for that initiator. 


DLM (Disable Loop Master) 


1 Indicates that a target attached to an FC-AL-2 loop shall not participate in loop master arbitration and shall not become loop master. The 
target shall only repeat LISM frames it receives. 


0 ‘The target may participate in loop master arbitration in the normal manner and, if successful, may become loop master during the loop 
initialization process. Targets not attached to an arbitrated loop shall ignore the DLM bit. 


REQUIRE HARD ADDRESS (RHA) bit - formerly DSA bit 


1 If the REQUIRE HARD ADDRESS (RHA) bit is set to one, a target FCP_Port attached to an arbitrated loop (see FCAL-2) shall only attempt to 
obtain its hard address available in the SCA-2 connector (see SFF-8067) or device address jumpers during loop initialization. 

The target FCP_Port shall not attempt to obtain an address during the LISA phase of initialization (see FC-AL-2). If there is a conflict for the hard 
address selection during loop initialization or the target FCP_Port does not have a valid hard address available, the target FCP_Port shall enter 
the nonparticipating state. If the target FCP_Port detects loop initialization while in the nonparticipating state, the target FCP_Port shall again 
attempt to get its hard address. If the hard address has not changed from the address obtained in a previous successful loop initialization, the 
target FCP_Port shall attempt to obtain the address in the LIFA phase if a valid Fabric Login exists or LIPA phase of loop initialization. If the hard 
address has changed, the target FCP_Port shall attempt to obtain the new address in the LIHA phase. 


0 If the RHA bit is set to zero, the target FCP_Port follows the normal initialization procedure, including the possibility of obtaining a soft 
address during the loop initialization process. 


Target FCP_Ports not attached to an arbitrated loop shall ignore the RHA bit. 
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DSA (Disable Soft Address) 


1 The target does not select a soft address if there is a conflict for the Select_ID address available in the SCA connector during loop initial- 
ization. If there is a Select_ID address conflict, the target enters the non-participation state. If the target detects loop initialization while 
in the non-participation state, the target again attempts to get the Select_ID address. 


0 ‘The target attempts to obtain a soft address during loop initialization if the Select_ID address is not available or if the Select_ID address 
indicates the use of a soft address (7Fh). 


If ESI activity is underway when the request for the hard address is received, the drive shall use the last known value of the hard address before 
the current ESI activity started. 


ALWLI (Allow Login Without Loop Initialization) 


1 The target uses the Select_ID address available in the SCA connector and accepts logins without verifying the address with loop initial- 
ization. 


0 ‘The target must verify the address through loop initialization before accepting a login. 


DTIPE (Disable Target Initiated Port Enable) 


1 The target waits for an initiator to send the Loop Port Enable primitive before inserting itself into the loop. The target uses the Select_ID 
address available in the SCA connector to determine if primitives are addressed to it. If the PLPB bit is set to one and the DTIPE bit is set 
to one, then the device server returns Check Condition status and sets the sense key to Illegal Request with the additional sense code 
set to Invalid Field in the Parameter List. 


0 = After completing self test, the target enables the port in the loop without waiting for a Loop Port Enable primitive. 


DTOLI (Disable Target Originated Loop Initialization) 


1 The target does not originate the initializing LIP following insertion into the loop. The target responds to an Initializing LIP when it is 
received. The target originates the Loop Failure LIP if it detects loop failure at its input. The target originates the Initializing LIP when the 
loop failure is corrected. 


0 = After completing self test, the target originates the Initializing LIP when it enables a port in a loop. 


SEQUENCE INITIATIVE RESOURCE RECOVERY TIMEOUT VALUE (RR_TOVSEQ_INIT) field 
The RR_TOVSEQ_INIT timer (see FCP-4) is defined by the RR_TOVSEQ_INIT field and the RR_TOV UNITS field. 
The RR_TOV UNITS field indicates the units for the RR_TOVSEQ_INIT field value, according to Table 409. 


Table 409 Values for RR_TOV UNITS 





























Pee Units of measure for 
bit2 | bit1 | bito RR_TOVSEQ_INIT 
0 0 0 No timer is specified 
0 0 1 0.001 s 
0 1 1 0.15 
1 0 1 10s 
All other values Reserved 














The RR_TOVSEQ_INIT field indicates the number of time units specified by the RR_TOV UNITS field that shall be used by the timer that performs the 
RR_TOVSEQ_INIT timeout function. If no timer is specified, the RR_TOVSEQ_INIT value shall be ignored by the device server and a vendor specific 
default value shall be used for RR_TOVSEQ_INIT. 
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5.3.26 Protocol-Specific Port mode page (19h) for SAS 


Parameters for direct access devices 


This clause describes the Protocol-Specific Port mode page implemented by products that are SAS-3 compliant. The 
Protocol-Specific Port mode page contains parameters that affect SSP target port operation. If the mode page is implemented 
by one logical unit in a SCSI target device, then it shall be implemented by all logical units in the SCSI target device that support 


the MODE SELECT or MODE SENSE commands. 


The mode page policy (see 5.4.14) for this mode page shall be either shared or per target port. If a SAS target device has multiple 


SSP target ports, then the mode page policy should be per target port. 
Parameters in this mode page: 


a) _ shall affect all phys in the SSP target port if the mode page policy is per target port; or 
b) — shall affect all SSP target ports in the SAS target device if the mode page policy is shared. 


Table 410 defines the format of the page for SAS. 


Table 410 _Protocol-Specific Port mode page for SAS 

































































Bit 7 6 5 4 3 0 
Byte 
0 PS SPF (0b) PAGE CODE (19h) 
1 PAGE LENGTH (OEh) 
BROADCAST 
2 reserved | CONTINUE | scyncHronous| READY LED PROTOCOL IDENTIFIER (6h) 
AWT MEANING 
EVENT 
3 Reserved 
4 (MSB) 
|_T NEXUS LOSS TIME 
5 (LSB) 
6 (MSB) 
INITIATOR RESPONSE TIMEOUT 
7 (LSB) 
8 (MSB) 
REJECT TO OPEN LIMIT 

9 (LSB) 
10 MAXIMUM ALLOWED XFER_RDY 

1 
eats Reserved 

15 








The PARAMETERS SAVEABLE (PS) bit is defined in 5.3.5. 

The SPF bit shall be set to zero for access to the short format mode page. 
The PAGE CODE field shall be set to 19h. 

The PAGE LENGTH field shall be set to OEh. 
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CONTINUE AWT BIT 


0 A CONTINUE AWT bit set to zero specifies that the SAS port shall stop the Arbitration Wait Time timer and set the Arbitration Wait Time 
timer to zero when it receives an OPEN_REJECT (RETRY). 


1 A CONTINUE AWT bit set to one specifies that the SAS port shall not stop the Arbitration Wait Time timer and shall not set the Arbitration 
Wait Time timer to zero when the SAS port receives an OPEN_REJECT (RETRY). 
BROADCAST ASYNCHRONOUS EVENT bit 


0  ABROADCAST ASYNCHRONOUS EVENT bit set to zero specifies that the device server shall disable origination of BROADCAST 
(ASYNCHRONOUS EVENT). 


1 A BROADCAST ASYNCHRONOUS EVENT bit set to one specifies that the device server shall enable origination of BROADCAST 
(ASYNCHRONOUS EVENT). 
READY LED MEANING bit 
The READY LED MEANING bit specifies the READY LED signal behavior. Regardless of the mode page policy (see 5.4.14) for this mode page, the 
shared mode page policy shall be applied to the READY LED MEANING bit. 
PROTOCOL IDENTIFIER field 
The PROTOCOL IDENTIFIER field is defined in 5.3.23 and shall be set to the value defined in table 410 indicating that this is a SAS specific mode 
page. 
|_T NEXUS LOSSTIME field 


The I_T NEXUS LOSS TIME field contains the time that the SSP target port shall retry connection requests to an SSP initiator port that are rejected 
with responses indicating the SSP initiator port may no longer be present before recognizing an |_T nexus loss. table 417 defines the values of the 
|_T NEXUS LOSS TIME field. If this mode page is not implemented, the I|_T nexus loss time is vendor specific. This value is enforced by the port layer. 


Table 411 1_TNEXUS LOSS TIME values 














Code Description 
0000h Vendor-specific amount of time. 
0001h to FFFEh Time in milliseconds. 
The SSP target port shall never recognize an |_T nexus loss 
FFFFh a 
(i.e., it shall retry the connection requests forever). 











INITIATOR RESPONSE TIMEOUT field 


The INITIATOR RESPONSE TIMEOUT field contains the time in milliseconds that the SSP target port shall wait for the receipt of a frame (e.g., a 
write DATA frame) before aborting the command associated with that frame. An INITIATOR RESPONSE TIMEOUT field value of zero indicates 
that the SSP target port shall disable the initiator response timeout timer. If this mode page is not implemented, the logical unit shall not 
implement an initiator response timeout timer. This value is enforced by the transport layer. 


REJECT TO OPEN LIMIT field 


The REJECT TO OPEN LIMIT field contains the minimum time in 10 us increments that the target port shall wait to establish a connection 
request with an initiator port on an |_T nexus after receiving an OPEN_REJECT (RETRY), OPEN_REJECT (RESERVED CONTINUE 0), or OPEN_RE- 
JECT (RESERVED CONTINUE 1). This value may be rounded as defined in 2.3. A REJECT TO OPEN LIMIT field set to 0000h indicates that the mini- 
mum time is vendor specific. This minimum time is enforced by the port layer. 


MAXIMUM ALLOWED XFER_RDY field 


The MAXIMUM ALLOWED XFER_RDY field specifies the maximum number of times a device server may call the Receive Data-Out transport pro- 
tocol service as described in 9.2.1.8. A MAXIMUM ALLOWED XFER_RDY field set to zero specifies that there is no limit to the number of times a 
device server may call the Receive Data-Out transport protocol service. 
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5.3.27 Phy Control And Discover subpage (19h/01h) 


The Phy Control And Discover subpage contains SAS phy-specific parameters. The mode page policy (see 5.4.14) for this 
subpage shall be shared. Parameters in this subpage shall affect only the referenced phy. 


Table defines the format of the subpage for SAS. 


Table 412 SAS - Phy Control And Discover subpage 


















































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (1b) PAGE CODE (19h) 
1 SUBPAGE CODE (01h) 
2 (MSB) 
———$————_ PAGE LENGTH (N - 3) 
3 (LSB) 
4 Reserved 
5 Reserved PROTOCOL IDENTIFIER (6h) 
6 GENERATION CODE 
7 NUMBER OF PHYS 


SAS phy mode descriptor list 








FIRST SAS PHY MODE DESCRIPTOR (see table 413) 








LAST SAS PHY MODE DESCRIPTOR (see table 413) 














The PARAMETERS SAVEABLE (PS) bit is defined in 5.3.5. 

The SPF bit (see 5.3.5) shall be set to one to access the long format mode pages. 

The PAGE CODE field (see 5.3.5) shall be set to 19h. 

The SUBPAGE CODE field (see 5.3.5) shall be set to O1h. 

The PAGE LENGTH field (see 5.3.5) shall be set to (4 + (the value of the NUMBER OF PHYS field) x (the length in bytes of the SAS phy mode 
descriptor)). 

PROTOCOL IDENTIFIER field 

The PROTOCOL IDENTIFIER field shall be set to 6h indicating this is a SAS specific mode page. 


GENERATION CODE field 


The GENERATION CODE field is a one-byte counter that shall be incremented by one by the device server every time the values in this mode 
page or the Enhanced Phy Control mode page (see 5.3.29) are changed. A GENERATION CODE field set to 00h indicates the generation code is 
unknown. The device server shall wrap this field to 01h as the next increment after reaching its maximum value (i.e., FFh). The GENERATION 
CODE field is also contained in the Enhanced Phy Control mode page (see 5.3.29) and the Protocol-Specific Port log page and may be used to 
correlate phy settings across mode page and log page accesses. 


NUMBER OF PHYS field 


The NUMBER OF PHYS field contains the number of phys in the SAS target device and indicates the number of SAS phy mode descriptors that 
follow. This field shall not be changeable with MODE SELECT. 
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SAS PHY MODE DESCRIPTOR fields 


A SAS phy mode descriptor shall be included for each phy in the SAS target device (not just the SAS target port), starting with the lowest num- 
bered phy and ending with the highest numbered phy. 


Table 413 defines the SAS phy mode descriptor. 


Parameters for direct access devices 








































































































Table 413. SAS phy mode descriptor 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 Reserved 
1 PHY IDENTIFIER 
2 
: Reserved 
4 Reserved ATTACHED DEVICE TYPE Reserved 
5 REASON NEGOTIATED PHYSICAL LINK RATE 
6 Reserved ATTACHED SSP ATTACHED STP ATTACHED SMP Recckyad 
INITIATOR PORT INITIATOR PORT INITIATOR PORT 
7 Racanied ATTACHED SSP ATTACHED STP ATTACHED SMP Aueaned 
TARGET PORT TARGET PORT TARGET PORT 
8 
SAS ADDRESS 
15 
16 
ATTACHED SAS ADDRESS 
23 
24 ATTACHED PHY IDENTIFIER 
25 
Reserved 
31 
32 PROGRAMMED MINIMUM PHYSICAL LINK RATE HARDWARE MINIMUM PHYSICAL LINK RATE 
33 PROGRAMMED MAXIMUM PHYSICAL LINK RATE HARDWARE MAXIMUM PHYSICAL LINK RATE 
34 
Reserved 
41 
42 
45 Vendor specific 
44 
Reserved 
47 
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PHY IDENTIFIER field 
The PHY IDENTIFIER field indicates the phy identifier (see SPL-3) of the phy for which information is being returned. 


ATTACHED DEVICE TYPE field 
The ATTACHED DEVICE TYPE field indicates the device type attached to this phy and is defined in Table 336. 


NEGOTIATED PHYSICAL LINK RATE field 
If the NEGOTIATED PHYSICAL LINK RATE field (see table 338) is not set to a physical link rate, then the management device server may set the 
ATTACHED DEVICE TYPE field to 000b. 
ATTACHED SSP INITIATOR PORT bit 
An ATTACHED SSP INITIATOR PORT bit set to: 
0 zero indicates that an SSP initiator port is not present in the attached device. 


1 one indicates that an SSP initiator port is present in the attached device. 


ATTACHED STP INITIATOR PORT bit 
An ATTACHED STP INITIATOR PORT bit set to one indicates that an STP initiator port is present in the attached device. 


ATTACHED SMP INITIATOR PORT bit 
An ATTACHED SMP INITIATOR PORT bit set to one indicates that an SMP initiator port is present in the attached device. 


ATTACHED SSP TARGET PORT bit 
An ATTACHED SSP TARGET PORT bit set to one indicates that an SSP target port is present in the attached device. 


ATTACHED STP TARGET PORT bit 
An ATTACHED STP TARGET PORT bit set to one indicates that an STP target port is present in the attached device. 


ATTACHED SMP TARGET PORT bit 
An ATTACHED SMP TARGET PORT bit set to one indicates that an SMP target port is present in the attached device. 


SAS ADDRESS field 

The SAS ADDRESS field indicates the port identifier (see SPL-3 r02, Section 4.2.9) of the SAS port transmitting the IDENTIFY address frame. For 
expander ports, the SAS ADDRESS field indicates the device name (see SPL-3 r02, Section 4.2.6) of the expander device transmitting the IDEN- 
TIFY address frame. 

ATTACHED SAS ADDRESS field 

The ATTACHED SAS ADDRESS field contains SAS address of the attached SAS port (see SPL-3 r02, Section 4.2.9). 


ATTACHED PHY IDENTIFIER 
The ATTACHED PHY IDENTIFIER field contains the phy identifier of the attached SAS phy in the attached SAS device. 


HARDWARE MINIMUM PHYSICAL LINK RATE field 


The HARDWARE MINIMUM PHYSICAL LINK RATE field indicates the minimum physical link rate supported by the phy. The values are defined in 
table 347. 
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HARDWARE MAXIMUM PHYSICAL LINK RATE field 


The HARDWARE MAXIMUM PHYSICAL LINK RATE field indicates the maximum physical link rate supported by the phy. The values are defined in 
table 347. If the phy is a virtual phy, this field should be set to the maximum physical link rate supported by the expander device. 


Table 414 The HARDWARE MINIMUM & MAXIMUM PHYSICAL LINK RATE field values 























Code Description 
Oh to 7h Reserved 
8h 1.5 Gbps 
9h 3.0 Gbps 
Ah 6.0 Gbps 
Bh 12.0 Gbps 
Ch to Fh Reserved for future physical link rates 














MAXIMUM PHYSICAL LINK RATE field 

MAXIMUM PHYSICAL LINK RATE field are defined in the SMP DISCOVER function (see SAS-3). These fields shall not be changeable with MODE 
SELECT. 

PROGRAMMED MINIMUM PHYSICAL LINK RATE field and PROGRAMMED MAXIMUM PHYSICAL LINK RATE field 


The PROGRAMMED MINIMUM PHYSICAL LINK RATE field and PROGRAMMED MAXIMUM PHYSICAL LINK RATE field are defined in the SMP PHY 
CONTROL function (see SPL-3 Section 9.4.3.28) for accesses with MODE SELECT commands and in the SMP DISCOVER function (see SPL-3 Sec- 
tion 9.4.3.10) for accesses with MODE SENSE commands. 


Table 415 lists the PROGRAMMED MINIMUM and MAXIMUM PHYSICAL LINK RATE field values. 


Table 415 The PROGRAMMED MINIMUM and MAXIMUM PHYSICAL LINK RATE field values 





























Code Description 
Oh Do not change current value 
Th to 7h Reserved 
8h 1.5 Gbps 
9h 3.0 Gbps 
Ah 6.0 Gbps 
Bh 12.0 Gbps 
Ch to Fh Reserved for future physical link rates 
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5.3.28 Shared Port Control mode page (19h/02h) 


The Port Control Mode Page contains parameters that affect SAS target port operation. If the mode page is implemented by one logical unit in a 
SCSI target device, then it shall be implemented by all logical units in the SCSI target device that support the MODE SELECT or MODE SENSE 
commands. 


The mode page policy (see 5.4.14) for this mode page shall be shared. 
Table 416 defines the format of this mode page. 


Table 416 Shared Port Control Mode Page 

































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PS SPF (1b) PAGE CODE (19h) 
1 SUBPAGE CODE (02h) 
2 (MSB) 

PAGE LENGTH (000Ch) 
3 (LSB) 
4 Reserved 
5 Reserved PROTOCOL IDENTIFIER (6h) 
6 (MSB) 

POWER LOSS TIMEOUT 
7 (LSB) 
8 Reserved 
9 POWER GRANT TIMEOUT 
10 

Reserved 

15 














The Parameters Saveable (PS) bit is defined in 5.3.5. 

The SubPage Format (SPF) bit is defined in 5.3.5 and shall be set to the value defined in table 416. 
The PAGE CODE field is defined in 5.3.5 and shall be set to the value defined in table 416. 

The SUBPAGE CODE field is defined in 5.3.5 and shall be set to the value defined in table 416. 

The PAGE LENGTH field is defined in 5.3.5 and shall be set to the value defined in table 416. 


PROTOCOL IDENTIFIER field 

The PROTOCOL IDENTIFIER field is defined in 5.3.5 and shall be set to the value defined in table 416 indicating that this is a SAS SSP specific 
mode page. 

POWER LOSS TIMEOUT field 


The POWER LOSS TIMEOUT field contains the maximum time, in one millisecond increments, that a target port shall respond to connection 
requests with OPEN_REJECT (RETRY) after receiving NOTIFY (POWER LOSS EXPECTED) (see SAS-3). A POWER LOSS TIMEOUT field set to 0000h 
specifies that the maximum time is vendor-specific. The power loss timeout shall be restarted on each NOTIFY (POWER LOSS EXPECTED) that is 
received. 


POWER GRANT TIMEOUT field 


The POWER GRANT TIMEOUT field contains the minimum time, in one second increments, that a SAS target device shall wait to receive a 
PWR_GRANT from a power source device. A POWER GRANT TIMEOUT field set to 00h specifies that the time limit is vendor specific. 
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5.3.29 Enhanced Phy Control mode page (19h/03h) 


The Enhanced Phy Control mode page contains parameters that affect SAS target phy operation. If the mode page is 
implemented by one logical unit in a SCSI target device, then it shall be implemented by all logical units in the SCSI target device 
that support the MODE SELECT or MODE SENSE commands. 


The mode page policy (see 5.4.14) for this mode page shall be shared. 
Table 417 defines the format of this mode page. 


Table 417 Enhanced Phy Control mode page 
















































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF(1b) PAGE CODE (19h) 
1 SUBPAGE CODE (03h) 
2 (MSB) 
PAGE LENGTH (n - 3) 
3 (LSB) 
4 Reserved 
5 Reserved PROTOCOL IDENTIFIER (6h) 
6 GENERATION CODE 
7 NUMBER OF PHYS 
Enhanced phy control mode descriptor list 
8 
aie Enhanced phy control mode descriptor (first) (see table 418) 
27 
n-19 
Enhanced phy control mode descriptor (last) (see table 418) 
n 











The Parameters Saveable (PS) bit is defined in 5.3.5. 

The SubPage Format (SPF) bit is defined in 5.3.5 and shall be set to the value defined in table 417. 

The PAGE CODE field is defined in 5.3.5 and shall be set to the value defined in table 417. 

The SUBPAGE CODE field is defined in 5.3.5 and shall be set to the value defined in table 417. 

The PAGE LENGTH field is defined in 5.3.5 and shall be set to the value defined in table 417 (i.e., 4 + (the value of the NUMBER OF PHYS field) ’ (the 
length in bytes of the SAS phy mode descriptor)). 

PROTOCOL IDENTIFIER field 

The PROTOCOL IDENTIFIER field is defined in 5.3.23 and shall be set to the value defined in table 417 indicating that this is a SAS specific mode 
page. 

GENERATION CODE field 

The GENERATION CODE field is defined in the Phy Control and Discover mode page (see 5.3.27). 


NUMBER OF PHYS field 


The NUMBER OF PHYS field contains the number of phys in the SAS target device and indicates the number of enhanced phy control mode 
descriptors in the enhanced phy control mode descriptor list. This field shall not be changeable with the MODE SELECT command. 


ENHANCED PHY CONTROL MODE DESCRIPTOR 


The enhanced phy control mode descriptor list contains an enhanced phy control mode descriptor for each phy in the SAS target device, not 
just the SAS target port, starting with the lowest numbered phy and ending with the highest numbered phy. 
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Table 418 defines the enhanced phy control mode descriptor. 


Table 418 Enhanced phy control mode descriptor 



















































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 Reserved 
1 PHY IDENTIFIER 
2 (MSB) 

DESCRIPTOR LENGTH (0010h) 
3 (LSB) 
4 
eas PROGRAMMED PHY CAPABILITIES 
7 
8 
ioe CURRENT PHY CAPABILITIES 
11 
12 

ATTACHED PHY CAPABILITIES 
15 
16 

Reserved 
17 
18 Reserved ee NEGOTIATED PHYSICAL LINK RATE 
HARDWARE 
19 Reserved MUXING 
SUPPORTED 








PHY IDENTIFIER field 
The PHY IDENTIFIER field indicates the phy identifier (see SPL-4) of the phy for which information is being returned. 


DESCRIPTOR LENGTH field 

The DESCRIPTOR LENGTH field contains the length in bytes that follow in the descriptor and shall be set to the value defined in table 418. 

The fields in the enhanced phy control mode descriptor not defined in this subclause are defined in the SMP DISCOVER response (see SPL-4). 
These fields shall not be changeable with the MODE SELECT command. 

PROGRAMMED PHY CAPABILITIES field 

The PROGRAMMED PHY CAPABILITIES field indicates the SNW-3 phy capabilities bits that are going to be transmitted in the next link reset 
sequence containing SNW-3 as defined in SPL-3 Section 5.7. 

CURRENT PHY CAPABILITIES field 


The CURRENT PHY CAPABILITIES field indicates the outgoing SNW-3 phy capabilities bits transmitted in the last link reset sequence as defined 
in SPL-4. If the last link reset sequence did not include SNW-3 or was a SATA link reset sequence, then the CURRENT PHY CAPABILITIES field shall 
be set to 00000000h. 
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ATTACHED PHY CAPABILITIES field 
The ATTACHED PHY CAPABILITIES field indicates the incoming SNW-3 phy capabilities bits received in the last SNW-3 as defined in SPL-4. If the 
last link reset sequence did not include SNW-3 or was a SATA link reset sequence, then the ATTACHED PHY CAPABILITIES field shall be set to 
00000000h. 
NEGOTIATED SSC bit 
A NEGOTIATED SSC bit set to: 
0 _ indicates that SSC is disabled 
1 indicates that SSC is enabled 
The NEGOTIATED SSC bit is only valid if the NEGOTIATED PHYSICAL LINK RATE field is greater than or equal to 8h. 


NEGOTIATED PHYSICAL LINK RATE field 
The NEGOTIATED PHYSICAL LINK RATE field is defined in table 338. If the phy is a physical phy, this field indicates the physical link rate negoti- 
ated during the link reset sequence. If the phy is a virtual phy, this field should be set to the maximum physical link rate supported by the 
expander device. The negotiated physical link rate may be less than the programmed minimum physical link rate or greater than the pro- 
grammed maximum physical link rate if the programmed physical link rates have been changed since the last link reset sequence. 
HARDWARE MUXING SUPPORTED bit 
A HARDWARE MUXING SUPPORTED bit set to: 

0 _ indicates that the phy does not support multiplexing 

1 indicates that the phy supports multiplexing 


This value is not adjusted based on the negotiated physical link rate. 
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5.3.30 


5.3.30.1 


SAS - Transceiver Control (Out) subpage (19h/E5h) 


Introduction 


Parameters for direct access devices 


The Transceiver Control (Out) subpage (see table 419) of the SAS Protocol-Specific Port mode page is used to adjust the 
transceiver parameter values of a phy. This subpage, when implemented, must comply with the following additional itemized 
requirements: 


1) The transceiver parameter settings may only be adjusted temporarily using the contents of this mode page, and cannot be saved. 


2) New phy settings are not to take effect until after status is returned for the MODE SELECT command that is issued to adjust the phy 
settings. 
3) The Transceiver Control subpage shall not be returned for a MODE SENSE command to return all pages. It shall only be returned to a 
MODE SENSE command, specifically, for the Transceiver Control subpage (19h/E5h). 
4) Transceiver Control Subpage E5h must include all mode descriptor for each link rate of each phy. For non-supported link rate, fill the 


mode descriptor bytes with 00. 








































































































Table 419 SAS Transceiver Control (Out) subpage 
Bit 7 6 5 4 3 2 0 
Byte 
0 PS SPF(1b) PAGE CODE (19h) 
1 SUBPAGE CODE (E5h) 
2 (MSB) 
PAGE LENGTH (n - 3) 
3 (LSB) 
4 Reserved 
5 Reserved PROTOCOL IDENTIFIER (6h) 
6 Reserved 
7 NUMBER OF PHYS (02h for a dual ported disk drive) 
8 
sate Reserved 
14 
15 TRANSCEIVER CONTROLS MODE DESCRIPTORS LENGTH 
16 Phy Transceiver Controls mode descriptor (first) PHY IDENTIFIER = 0 
CONTROLLABLE LINK RATE = 08h 
32 Phy Transceiver Controls mode descriptor (first) PHY IDENTIFIER = 0 
CONTROLLABLE LINK RATE = 09h 
48 Phy Transceiver Controls mode descriptor (first) PHY IDENTIFIER = 0 
CONTROLLABLE LINK RATE = OAh 
64 Phy Transceiver Controls mode descriptor (first) PHY IDENTIFIER = 0 
CONTROLLABLE LINK RATE = OBh 
80 Phy Transceiver Controls mode descriptor (second) PHY IDENTIFIER = 1 
CONTROLLABLE LINK RATE = 08h 
96 Phy Transceiver Controls mode descriptor (second) PHY IDENTIFIER = 1 
CONTROLLABLE LINK RATE = 09h 
112 Phy Transceiver Controls mode descriptor (second) PHY IDENTIFIER = 1 
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Table 419 SAS Transceiver Control (Out) subpage 





Bit 7 6 5 4 3 2 1 0 
Byte 


























CONTROLLABLE LINK RATE = OAh 








128 Phy Transceiver Controls mode descriptor (second) PHY IDENTIFIER = 1 
CONTROLLABLE LINK RATE = OBh 











144 00 














The PARAMETERS SAVEABLE (PS) bit is defined in SPC-5. 

The SUBPAGE FORMAT (SPF) bit is defined in SPC-5 and shall be set to the value defined in table 419. 
The PAGE CODE field is defined in SPC-5 and shall be set to the value defined in table 419. 

The SUBPAGE CODE field is defined in SPC-5 and shall be set to the value defined in table 419. 


PAGE LENGTH field 

The PAGE LENGTH field is defined in SPC-5 and shall be set to the value defined in table 419 (i.e., 4 + (the value of the NUMBER OF PHYS field) x 
(the length in bytes of the SAS phy mode descriptor). 

PROTOCOL IDENTIFIER field 

The PROTOCOL IDENTIFIER field is defined in SPC-5 and shall be set to the value defined in table 419 indicating that this is a SAS specific mode 
page. 

NUMBER OF PHYS field 


The NUMBER OF PHYS field contains the number of phys in the SAS target device and indicates the number of enhanced phy control mode 
descriptors in the enhanced phy control mode descriptor list. If a target device has 2 operational target ports (2 phys), then this field shall be set 
to 2h. Target devices with only one port shall set this field to 1h. This field shall not be changeable with the MODE SELECT command. 


TRANSCEIVER CONTROLS MODE DESCRIPTORS LENGTH fields 


This Transceiver Controls Mode Descriptors Length fields shall contain the total length in bytes of each phy's transceiver controls mode 
descriptor. Since the descriptors are the same length, this value is not provided in each descriptor, but rather, once in this subpage prior to the 
descriptor(s). The field is unchangeable. 


SCSI Commands Reference Manual, Rev. J 449 


www.seagate.com Parameters for direct access devices 


5.3.30.2 Transceiver Controls Mode descriptors 


Detail for the mode descriptor(s) for transceiver controls can be found in Table 420 and Table 421. Each field is defined below the 
table. All supported link rates and controls shall be listed in page E5h. 


Table 420 _‘ Transceiver Controls Mode descriptor (1.5Gb - 6Gb Link Rate) 



































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PHY IDENTIFIER 
1 CONTROLLABLE LINK RATE 
2 DRIVER STRENGTH CONTROL 
3 DRIVER EMPHASIS CONTROL 
4 DRIVER SLEW RATE CONTROL 
5 
MANUFACTURER DEFINE BYTES FOR TRANSMITTER CONTROL 
8 
9 RECEIVER THRESHOLD CONTROL 
10 RECEIVER EQUALIZATION GAIN CONTROL 
~ MANUFACTURER DEFINE BYTES FOR RECEIVER CONTROL 
13 INTERNAL RX EYE MARGIN RESET Reserved Reserved IREC 
14 INTERNAL RX EYE HEIGHT 
15 INTERNAL RX EYE WIDTH 














Table 421 ‘Transceiver Controls descriptor (12Gb Link Rate) 
















































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PHY IDENTIFIER 
1 CONTROLLABLE LINK RATE 
2 C1 VALUE OF TX 
3 C2 VALUE OF TX 
4 C3 VALUE OF TX 
5 Reserved RESET Reserved REG IREC 
COMPLETED 
6 FFE COEFFICIENT 0 / INTERNAL RX EYE HEIGHT MARGIN 
7 FFE COEFFICIENT 1 / INTERNAL RX EYE HEIGHT MARGIN 
8 DFE COEFFICIENT 0 
9 DFE COEFFICIENT 1 
10 DFE COEFFICIENT 2 
11 DFE COEFFICIENT 3 
12 DFE COEFFICIENT 4 
13 HOST C1 RELATIVE VALUE 
14 HOST C2 RELATIVE VALUE 
15 HOST C3 RELATIVE VALUE 
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PHY IDENTIFIER field 

SAS devices may have more than one target port. If a target device has 2 operational target ports (2 phys - primary and secondary port), then 
this field shall be set to either Oh for the primary port or 1h for the secondary port. This field is unchangeable. 

CONTROLLABLE LINK RATE field 

The Controllable Link Rate field shall contain the controllable link rate for the phy. Table 422 lists the supported values Controllable Link Rates. 
This field is not changeable. 


Table 422 Controllable Link Rates 


























Value Definition 

0x00 Phy exists, but does not support “Transceiver Control” controls 
0x01 - 0x07 Reserved 

0x08 Phy supports Transceiver Control controls for 1.5 Gbps 

0x09 Phy supports Transceiver Control controls for 3.0 Gbps 

0x0A Phy supports Transceiver Control controls for 6.0 Gbps 

0x0B Phy supports Transceiver Control controls for 12.0 Gbps 

Ox0C - OxFF Reserved 














DRIVER STRENGTH CONTROL or C1 PRE-CURSOR CONTROL (12Gb only) field 


This field shall contain either the user input (MODE SELECT) or current (MODE SENSE) driver strength output or the 12G mode pre-cursor C1 
setting of the SAS transmitter. If the user input setting is out of range of the transceiver capability, the target device shall return a CHECK CON- 
DITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST for the MODE 
SELECT command. This field shall be supported as described in Table 423. The field is changeable but not savable. 


Table 423. DRIVER STRENGTH CONTROL or C1 PRE-CURSOR CONTROL (12G Mode Only) values 














Value Definition 
0x66 (write only) Write 66h shall reset the driver strength setting back to factory default value. 
(1.5G - 6G) 
0x00 - Range Limit User input for driver strength control setting or C1 pre-cursor setting. 
(write only) If the new user input is out of range specified in subpage 19h/E5h, 
the target device shall maintain the current setting. 
Read Only The current setting value shall be displayed. 








SCSI Commands Reference Manual, Rev. J 451 


www.seagate.com Parameters for direct access devices 


DRIVER EMPHASIS CONTROL or C2 AMPLITUDE CONTROL (12G Mode Only) field 


This field shall contain either the user input (MODE SELECT) or current (MODE SENSE) driver emphasis setting the 12G mode amplitude C2 set- 
ting of the SAS transmitter. If the user input setting is out of range of the transceiver capability, the target device shall return a CHECK CONDI- 
TION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST for the MODE 
SELECT command. This field shall be supported as described in Table 424. This field is changeable but not savable. 


Table 424 DRIVER EMPHASIS CONTROL or C2 AMPLITUDE CONTROL (12G Mode Only) 

















Value Definition 
0x66 (write only) Write 66h shall reset the driver pre-emphasis setting back to factory default value. 
(1.5G - 6G) 
0x00 - Range Limit User input for driver pre-emphasis control setting or C2 amplitude setting. 
(write only) If the new user input is out of range specified in subpage 19h/E5h, 
the target device shall maintain the current setting. 
Read Only The current setting value shall be displayed. 











DRIVER SLEW RATE CONTROL or C3 CONTROL (12G Mode Only) field 


This field shall contain either the user input (MODE SELECT) or current (MODE SENSE) driver slew rate setting of the target device SAS phy. If the 
user input setting is out of range of the transceiver capability, the target device shall return a CHECK CONDITION status with the sense key set 
to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST for the MODE SELECT command. This field shall be 
supported as described in Table 425. This field is changeable but not savable. 


Table 425 DRIVER SLEW RATE CONTROL or C3 POST CURSOR CONTROL (12G mode only) 








Value Definition 

0x66 (write only) Write 66h shall reset the driver slew rate setting back to factory default value. 
(1.5G - 6G) 

0x00 - Range Limit User input for driver slew rate control setting or C3 post cursor setting. 


If the new user input is out of range specified in subpage 19h/E5h, 


(write only) : nee : 
the target device shall maintain the current setting 














Read Only The current setting value shall be displayed. 





MANUFACTURER DEFINED BYTES FOR TRANSMITTER CONTROL field 


The manufacturer Defined Bytes For Transmitter Control field may be used by the manufacturer who needs additional control bytes for the 
transmitter. All control bytes shall accept 66h as reset code which change the control byte back to factory default setting. If the user input set- 
ting is out of range of the transceiver capability, the target device shall return a CHECK CONDITION status with the sense key set to ILLEGAL 
REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST for the MODE SELECT command. 
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RECEIVER THRESHOLD CONTROL field 


The Receiver Threshold Control field contains either the user input (MODE SELECT) or current (MODE SENSE) receiver threshold setting of the 
target device SAS phy. If the user input setting is out of range of the transceiver capability, the target device shall return a CHECK CONDITION 
status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST for the MODE 


SELECT command. The Receiver Threshold Control field shall be supported as described in table 426. This field is changeable but not savable. 


Table 426 Receiver Threshold Control 




















Value Definition 

0x66 (write only) Write 66h shall reset the receiver threshold setting back to factory default value. 

0x00 - Range Limit User input for receiver threshold control setting. If the new user input is out of range specified in 
(write only) subpage 19h/E5h, the target device shall maintain the current setting. 

Read Only The current setting value shall be displayed. 








RECEIVER EQUALIZATION GAIN CONTROL field 


The Receiver Equalization Gain Control field contains either the user input (MODE SELECT) or current (MODE SENSE) receiver equalization gain 
setting of the target device SAS phy. If the user input setting is out of range of the transceiver capability, the target device shall return a CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST for the 


MODE SELECT command. This field shall be supported as described in table 427. This field is changeable but not savable. 


Table 427 Receiver Equalization Gain Control field 





Value 


0x66 (write only) 


Definition 


Write 66h shall reset the receiver equalization gain setting back to factory default value for the driver 
voltage. 





0x00 - Range Limit 
(write only) 


User input for receiver equalization gain control setting. If the new user input is out of range 
specified in subpage 19h/E5h, the target device shall maintain the current setting 





Read Only 


The current setting value shall be displayed. 














MANUFACTURER DEFINED BYTES FOR RECEIVER CONTROL field 


The Manufacturer Defined Bytes For Receiver Control field may be used by manufacturer who needs additional control bytes for the receiver. 
All control bytes shall accept 66h as reset code which change the control byte back to factory default setting. If the user input setting is out of 
range of the transceiver capability, the target device shall return a CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID FIELD IN PARAMETER LIST for the MODE SELECT command. 


EYE WIDTH MARGIN and EYE HEIGHT MARGIN field - Read Only 


These fields shall contain IRE margin after IREC (Internal RX Eye Capture) is performed. The margin calculation are based on the following for- 
mula: 


Eye Width Margin = (Captured Eye Width - Spec Min Eye Width) / Spec Min Eye Width x 100% 
Eye Height Margin = (Captured Eye Height - Spec Min Height Width) / Spec Min Eye Height x 100% 
In case the Captured Eye is less than Spec Min. Eye, then FFh should be used. 


IREC (INTERNAL RX EYE CAPTURE) bit 
This bit controls the Internal RX Eye Capture process (see table 427), and provides the internal eye height, eye width and eye margin. 


IREC COMPLETED bit - Read Only 


This bit indicates the Internal RX Eye Capture process (see table 427) is completed and provides the internal eye height, eye width and eye mar- 
gin. 


SCSI Commands Reference Manual, Rev. J 453 


www.seagate.com Parameters for direct access devices 


RESET bit 
This bit controls the TX to C1, C2 and C3, and controls the reset function of IREC bits (see table 427). 


Table 428 RESET and IREC bit function 





RESET | IREC IREC Mode Sense data after Mode Select was executed 
(Mode | (Mode | Completed | with different RESET bit and IREC bit settings. 
Select) | Select) 








0 0 0) n Nochange on current C1, C2, C3 
n All FFE and DFE coefficients shall be updated 
0 0 1 n Set IREC Completed bit to 1 when RX eye capture is completed 


n IRC Margin shall be displayed 
n RX eye height and eye width shall be displayed instead of RX FFE coefficients. 
n All DFE coefficients shall be updated 





1 0 Don't n  SetTX to C1, C2, C3 (no retrain) 





ale n All FFE and DFE coefficients shall be updated 
n_ After reset operation completed, Reset bit shall be set to 0, 
IREC Completed bit shall be set to 0. 
n__ All FFE and DFE coefficients shall be updated. 
1 1 Don't n  Nochange on current C1, C2, C3 
Care 


n Perform internal RX eye capture 


n _ After RX eye capture completed, 
Reset bit shall be set to 0 and IREC Completed bit shall be set to 1. 


n IRC Margin shall be displayed 
n RX eye height and eye width shall be displayed instead of RX FFE coefficients. 
n All DFE coefficients shall be updated 




















FFE TAP 0, 1 / RX EYE HEIGHT AND RX EYE WIDTH (Read only) 

The FFE Tap 0, 1 field shall contain the current (MODE SENSE) FFE Tap 0 and Tap 1 coefficient with the RESET bit is set to 0 and IREC Completed 
bit set to 0. The RX Eye Height And RX Eye Width fields shall contain the current (MODE SENSE) RX eye height and RX eye width with IREC com- 
pleted bit set to 1. 

DFE COEFFICIENT 0 - 4 (Read only) 

This field shall contain the current (MODE SENSE) DFE coefficient of the receiver. If the number of DFE coefficients is more than 5, then only the 
first 5 coefficients shall be displayed. 

HOST TRANSMITTER C1, C2 AND C3 RELATIVE SETTING (Read Only) 

This field shall contain the user input (MODE SELECT) of the C1, C2 and C3 relative setting of host transmitter. 


During the speed negotiation, the C1, C2 and C3 of the Host transmitter will be adjusted by Up or Hold or Down. 
Keep track of the adjustment by each Up = +1, each Hold = 0 and each Down = -1, i.e. C1 is adjusted by 3 Up tics and 1 Down, 
the relative Host C1 is 1+1+1-1 =2. 
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5.3.31 


5.3.31.1 


SAS - Transceiver Control (In) subpage (19h/E6h) 


Introduction 


Parameters for direct access devices 


The Transceiver Control (In) subpage of the SAS Protocol-Specific Port mode page (see table 429) is used to return the 
transceiver parameter values of a phy. The Transceiver Control subpage shall not be returned for a MODE SENSE command to 
return all pages. It shall only be returned to a MODE SENSE command, specifically, for the Transceiver Control subpage (19h/E6h). 
The target device shall return a CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense 
code set to INVALID FIELD IN PARAMETER LIST for a MODE SELECT command issued for this subpage. 





























































































































Table 429 SAS - Transceiver Control (In) subpage 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (1b) Page Code (19h) 
SUBPAGE CODE (E6h) 
2 (MSB) 
3 PAGE LENGTH (n-3) (SB) 
4 Reserved 
5 Reserved PROTOCOL IDENTIFIER (6h) 
6 Reserved 
7 NUMBER OF PHYS (02h for a dual ported disk drive) 
8 
Reserved 
14 
15 TRANSCEIVER CONTROLS MODE DESCRIPTOR LENGTH = 16 
16 Phy Transceiver Controls mode descriptor (first) PHY IDENTIFIER = 0 
CONTROLLABLE LINK RATE = 08h 
32 Phy Transceiver Controls mode descriptor (first) PHY IDENTIFIER = 0 
CONTROLLABLE LINK RATE = 09h 
48 Phy Transceiver Controls mode descriptor (first) PHY IDENTIFIER = 0 
CONTROLLABLE LINK RATE = OAh 
64 Phy Transceiver Controls mode descriptor (first) PHY IDENTIFIER = 0 
CONTROLLABLE LINK RATE = OBh 
80 Phy Transceiver Controls mode descriptor (second) PHY IDENTIFIER = 1 
CONTROLLABLE LINK RATE = 08h 
96 Phy Transceiver Controls mode descriptor (second) PHY IDENTIFIER = 1 
CONTROLLABLE LINK RATE = 09h 
112 Phy Transceiver Controls mode descriptor (second) PHY IDENTIFIER = 1 
CONTROLLABLE LINK RATE = OAh 
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128 Phy Transceiver Controls mode descriptor (second) PHY IDENTIFIER = 1 
CONTROLLABLE LINK RATE = OBh 











144 00 














The PARAMETERS SAVEABLE (PS) bit is defined in SPC-5. 

The SUBPAGE FORMAT (SPF) bit is defined in SPC-5 and shall be set to the value defined in table 429. 
The PAGE CODE field is defined in SPC-5 and shall be set to the value defined in table 429. 

The SUBPAGE CODE field is defined in SPC-5 and shall be set to the value defined in table 429. 


PAGE LENGTH field 

The PAGE LENGTH field is defined in SPC-5 and shall be set to the value defined in table 429 (i.e., 4 + (the value of the NUMBER OF PHYS field) x 
(the length in bytes of the SAS phy mode descriptor). 

PROTOCOL IDENTIFIER field 

The PROTOCOL IDENTIFIER field is defined in SPC-5 and shall be set to the value defined in table 429 indicating that this is a SAS specific mode 
page. 

NUMBER OF PHYS field 

SAS devices may have more than one target port. If a target device has 2 operational target ports (2 phys), then this field shall be set to 2h. Tar- 
get devices with only one port shall set this field to 1h. The field is unchangeable. 

TRANSCEIVER CONTROLS MODE DESCRIPTOR LENGTH field 


The Transceiver Controls Mode Descriptor Length field shall contain the total length in bytes of each phy’s transceiver controls mode descrip- 
tor. Since the descriptors are the same length, this value is not provided in each descriptor, but rather, once in this subpage prior to the descrip- 
tor(s). The field is unchangeable. 
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5.3.31.2 Transceiver Controls Mode descriptors 


Detail for the mode descriptor(s) for transceiver controls can be found in Table 430 and Table 431. Each field is defined below the 
table. All supported link rates and controls shall be listed in page E5h. 


Table 430 _‘ Transceiver Controls descriptor (1.5Gb - 6Gb Link Rate) 



































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PHY IDENTIFIER 
1 CONTROLLABLE LINK RATE 
2 DRIVER STRENGTH CONTROL 
3 DRIVER EMPHASIS CONTROL 
4 DRIVER SLEW RATE CONTROL 
5 
MANUFACTURER DEFINED BYTES FOR TRANSMITTER CONTROL 
8 
RECEIVER THRESHOLD CONTROL 
10 RECEIVER EQUALIZATION GAIN CONTROL 
7 MANUFACTURER DEFINE BYTES FOR RECEIVER CONTROL 
13 INTERNAL RX EYE MARGIN RESET Reserved Reserved IREC 
14 INTERNAL RX EYE HEIGHT 
15 INTERNAL RX EYE WIDTH 
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Table 431‘ Transceiver Controls descriptor (1.5G, 3G, 6G and 12G) 




































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PHY IDENTIFIER 
1 CONTROLLABLE LINK RATE 
2 MAX DRIVER STRENGTH CONTROL 
[12G: MAX C1 WHEN C2 AND C3 ARE SET TO MIN] 
3 MAX DRIVER EMPHASIS CONTROL 
[12G: MAX C1 WHEN C1 AND C3 ARE SET TO 0] 
4 MAX DRIVER SLEW RATE CONTROL 
[12G: MAX C1 WHEN C1 AND C2 ARE SET TO MIN] 
5 DRIVER STRENGTH CONTROL CHANGE PER STEP 
[12G: C1 CHANGE PER STEP] 
6 DRIVER EMPHASIS CONTROL CHANGE PER STEP 
[12G: C2 CHANGE PER STEP] 
7 DRIVER SLEW RATE CONTROL CHANGE PER STEP 
[12G: C2 CHANGE PER STEP] 
Reserved (00h) 
MAX RECEIVER THRESHOLD CONTROL 
10 MAX RECEIVER EQUALIZATION GAIN CONTROL 
11 RECEIVER THRESHOLD CONTROL CHANGE PER STEP 
12 RECEIVER EQUALIZATION GAIN CONTROL CHANGE PER STEP 
13-15 Reserved 














PHY IDENTIFIER field 


SAS devices may have more than one target port. If a target device has 2 operational target ports (2 phys - primary and secondary port), then 
this field shall be set to either Oh for the primary port or 1h for the secondary port. The field is unchangeable. 


CONTROLLABLE LINK RATE field 
This field shall contain the controllable link rate for the phy. Table 432 lists the supported values for the field. This field is not changeable. 


Table 432 Controllable Link Rates field 























Value Definition 

0x00 Phy exists, but does not support Transceiver Control controls 
0x01 - 0x07 Reserved 

0x08 Phy supports Transceiver Control controls for 1.5 Gbps 

0x09 Phy supports Transceiver Control controls for 3.0 Gpbs 

Ox0A Phy supports Transceiver Control controls for 6.0 Gbps 

0x0B Phy supports Transceiver Control controls for 12.0 Gbps 
Ox0C - OxFF Reserved 














MAX DRIVER STRENGTH CONTROL or C1 MAX SETTING when C2 and C3 set to MIN (12G Mode Only) field 
This field shall contain the max allowable driver strength output setting of the target device SAS phy. The field is changeable but not savable. 


MAX DRIVER EMPHASIS CONTROL or C2 MAX SETTING when C1 and C3 set to 0 (12G Mode Only) field 


This field shall contain the max allowable driver emphasis setting of the target device SAS phy. This field is changeable but not savable. 
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MAX DRIVER SLEW RATE CONTROL or C3 CONTROL (12G Mode Only) field 


This field shall contain the max allowable driver slew rate setting of the target device SAS phy. This field is changeable but not savable. 


DRIVER STRENGTH CONTROL CHANGE PER STEP or C1 CONTROL (12G Mode Only) field 

This field shall contain the approximate voltage change (in mV unit) for each increment or decrement of driver strength control setting. The 
field is unchangeable. 

DRIVER EMPHASIS CONTROL CHANGE PER STEP or C2 CONTROL (12G Mode Only) field 

This field shall contain the approximate percentage of amplitude change (in % unit) for each increment or decrement of driver emphasis con- 
trol setting. This field shall be used to establish the transceiver driver pre-emphasis or de-emphasis. The field value should be treated as a 
2's-complement signed value that can range from 1 to +100 for pre-emphasis, or -1 to -100 for de-emphasis. The field is unchangeable. 
DRIVER SLEW RATE CONTROL CHANGE PER STEP or C3 CONTROL (12G Mode Only) field 

This field shall contain the approximate slew rate change (in mV/nsec unit) for each increment or decrement of driver slew rate control setting. 
The field is unchangeable. 

MAX RECEIVER THRESHOLD CONTROL field 

This field contains max allowable threshold setting of the target device SAS phy. The field is unchangeable. 


MANUFACTURER DEFINED BYTES INFO FOR TRANSMITTER CONTROL field 


This field can be used by manufacturer who needs additional control bytes for the transmitter. 


MAX RECEIVER EQUALIZATION GAIN CONTROL field 


This field contains the max allowable receiver equalization gain setting of the target device SAS phy. The field is unchangeable. 


RECEIVER THRESHOLD CONTROL CHANGE PER STEP field 

This field shall contain the approximate voltage change (in mV unit) for each increment or decrement of receiver threshold control setting. The 
field is unchangeable. 

RECEIVER EQUALIZATION GAIN CONTROL CHANGE PER STEP field 

This field shall contain the approximate gain change for each increment or decrement of receiver equalization gain control setting. The field is 
unchangeable. 

MANUFACTURER DEFINED BYTES INFO FOR RECEIVER CONTROL field 


This field can be used by manufacturer who needs additional control bytes for the receiver. 
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5.3.32 Rigid Drive Geometry Parameters page (04h) 


This mode page has been declared obsolete by the T10 committee. However, it is included because it may be implemented on 
some products. 


The Rigid Drive Geometry Parameters page implementation is defined in Table 433 . This table summarizes the function and 
defines the default value. 


Table 433 Rigid Drive Geometry Parameters page (04h) 































































































Bit 7 6 5 4 3 2 1 0 

Byte 
0 PS SPF (Ob) PAGE CODE (04h) 
1 PAGE LENGTH (16h) 
2 NUMBER OF CYLINDERS (MSB) 
3 NUMBER OF CYLINDERS 
4 NUMBER OF CYLINDERS (LSB) 
5 NUMBER OF HEADS 

6,7,8 STARTING CYLINDER—WRITE PRECOMP 

9,10,11 STARTING CYLINDER—REDUCED WRITE CURRENT 
12,13 DRIVE STEP RATE 
14,15,16 LANDING ZONE CYLINDER 
17 0 0 0 0 0 0 RPL 
18 ROTATIONAL OFFSET XXh 
19 Reserved 
20 (MSB) 
MEDIUM ROTATION RATE —— 

21 (LSB) 
22 Reserved 
23 Reserved 














PS (Parameter Savable) bit 


The Parameter Savable (PS) bit of 1 indicates that page 04 parameter data is savable and is saved when a Format Function is performed. In 
some drives an exception exists that applies to bytes 17 and 18. In the exception drives, bytes 17 and 18 are only saved if the SMP bit in the 
MODE SELECT command (Table 70) is 1. See individual drive’s Product Manual, Volume 1, SCSI bus conditions and miscellaneous features sup- 
ported.’ This PS bit is not applicable to the MODE SELECT command. 


SPF bit 
The SPF bit is described in 5.2.2 and shall be set as shown in table 433. 
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PAGE CODE field 
The PAGE CODE field is defined in SPC-5 and shall be set to the value defined in table 433. 


PAGE LENGTH field 
The PAGE LENGTH field is defined in SPC-5 and shall be set to the value defined in table 433. 


NUMBER OF CYLINDERS field 


The NUMBER OF CYLINDERS field defines the number of physical cylinders used for data storage. This may or may not include spare cylinders 
set aside for flaw reallocation. See individual drive’s Product Manual, Volume 1, which specifies what the drive reports. 


The drive uses some additional cylinders for storing drive parameters, defect lists, or for diagnostic purposes. These are not accessible by the 
user. 


NUMBER OF HEADS field 
The NUMBER OF HEADS field indicates the maximum number of data (read/write) heads on the drive. 


STARTING CYLINDER—WRITE PRECOMP, STARTING CYLINDER—REDUCED WRITE CURRENT, DRIVE STEP RATE, and LANDING ZONE 
CYLINDER fields 


Not applicable. 


RPL (rotational position locking) field 
Not supported. 


ROTATIONAL OFFSET field 
Not supported. 


MEDIUM ROTETION RATE field 


On MODE SENSE command, these bytes return drive nominal rotation rate in revolutions per minute for synchronous spindle operation. The 
bytes have no meaning for MODE SELECT. 


See individual drive’s Product Manual, MODE SENSE Data clause, for changeable values. 


SCSI Commands Reference Manual, Rev. J 461 


www.seagate.com 


5.3.33 
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Seagate Specific Unit Attention parameters page (00h) for HDD 


The Seagate Specific Unit Attention parameters page is the last page to be reported by the drive. 

























































































Table 434 Seagate Specific Unit Attention parameters page (00h) for HDD 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (Ob) PAGE CODE (00h) 
1 PAGE LENGTH (0Ah) 
2 PM Reserved INQUIRY LENGTH | UNIT ATTENTION Reserved ROUND STRICT SCSI-2 
3 DAR a Reserved 
4 oo es Reserved JIT3 JIT2 JIT] JITO 
5 Reserved 
6 Reserved 
7 Reserved 
8 Reserved 
9 Reserved 
10 (MSB) 
COMMAND AGING LIMIT 
11 (LSB) 














PS (Parameter Savable) bit 


A Parameter Savable (PS) bit of one indicates that the drive is capable of saving the page in a nonvolatile vendor-specific location (used only 
with MODE SENSE command). 


SPF bit 


The SPF bit is described in 5.2.2 and shall be set as shown in table 434. 


PAGE CODE field 
The PAGE CODE field is defined in SPC-5 and shall be set to the value defined in table 434. 


PAGE LENGTH field 


The PAGE LENGTH field specifies the length in bytes of the mode parameters that follow. If the initiator does not set this value to the value that 
is returned for the page by the MODE SENSE command, the drive shall terminate the command with CHECK CONDITION status. The sense key 
shall be set to ILLEGAL REQUEST with the additional sense code set to Invalid Field In Parameter List. See STRICT bit set to 0 description for 


exceptions. 
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PM (Performance Mode) bit 


The PM (Performance Mode) bit is used to control the drive’s cache management algorithm to allow best performance in different types of sys- 
tems. It is the initiator’s responsibility to determine which setting is best for that system. 


1 A PM value of 1 indicates that the number of cache segments is fixed to the value set in mode page 08h. 
0 APM value of 0 indicates that the drive will optimize the number of segments depending on the command activity observed by the 
drive. The number of segments value (in mode page 08h) is ignored with the PM value is 0. 
IL (INQUIRY Length) bit 


1 When the INQUIRY Length (IL) bit is set to one, the standard INQUIRY data available to a host is limited to the 36 bytes required by the 
SCSI-2 specification. 


0 When the IL bit is set to zero, 148 bytes of standard INQUIRY data are available. The Additional Length field in byte 4 of the INQUIRY data 
is updated to reflect the actual number of additional bytes available. 
UNIT ATTENTION bit 


1 When the UNIT ATTENTION bit is set to one, then UNIT ATTENTION is logged in sense only; no CHECK CONDITION status is presented fol- 
lowing any reset. 


0 When this bit is set to zero, then Check Condition is presented for all affected initiators following a reset until REQUEST SENSE is issued 
by each initiator (as per current operation). 
ROUND bit 
1 When the ROUND bit is set to one, the drive treats and reports rounded parameters as described in 2.3. 
QO When ROUND is set to zero, the drive shall round the parameter and handle command completion reporting as if the parameter had not 
been rounded. 
STRICT bit 


1 When the STRICT bit is set to one, the drive checks for initiator attempts to change unchangeable parameters. If the drive detects an 
attempt, it rejects the command in the standard way, i.e., CHECK CONDITION status from drive, REQUEST SENSE from the initiator, and 
Illegal Request Sense key (5h) back from the drive. 


O When the STRICT bit is set to zero, the drive ignores the values of the unchangeable parameters ina MODE SELECT command. The drive 
does not reject the command trying to change unchangeable parameters or trying to send a mode page that is shorter than the sup- 
ported length. 


Caution: — Utilization of this forgiving option by a SCSI initiator port that does not analyze the impact of the truncation could adversely 
COMMAND AGING LIMIT field. 
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SCSI-2 bit 
1 When set to one, the SCSI-2 bit changes the following SCSI-3 features from their SCSI-3 definition to the SCSI-2 definition: 
a) Control Mode Page (OAh) Length from OAh to 06h; and 
b) Caching Page (08h) Length from 12h to OAh. 


0 When 82 is set to zero, all features remain as specified in other portions of this specification. 


DAR (Deferred Auto Reallocation) bit 


1 Deferred reallocation is enabled. When an unrecoverable read error occurs, the drive remembers the LBA of the error; when a subse- 


quent write command occurs for that LBA and the AWRE bit in mode page 1 is enabled, then the LBA is reallocated before the write 
command is completed. 


0 Deferred reallocation is disabled. 


Self Seek bit 


1 If the Self Seek bit is set to one, the drive will enter self seek mode for testing purposes. Such testing could include, but is not limited to, 
power dissipation and acoustics. While in this mode, the drive will accept SCSI commands and will process them in between the self 
seek operations, including a MODE SELECT to turn this bit back off. As such, this bit should be off for normal drive operations. 


0 If this bit is set to zero, the drive will not self seek; normal operating mode. 


VJIT Disabled bit 
1 When this bit is set to 1, the drive will always use the fastest seek type (i.e., JIT 0). JIT bits 0:3 of byte 4 are ignored. 
0 When this bit is set to 0, the drive will operate according to the settings of JIT bits 0:3. 


JIT (Just in Time) bits 


The four JIT Just In Time) bits allow you to enable and disable certain seek speeds. JITO represents the fastest seek type used by the drive, JIT1 
represents the second fastest, JIT2 represents the third fastest, and JIT3 represents the slowest seek type. You can use these bits to reduce 
acoustics by disabling the fastest seeks. This can also reduce power consumption (from seek activity). These JIT settings only affect user read 
and write operations. Background drive operations and user seek commands will always use the fastest seek type. When the bit is set to 1, the 
drive is allowed to use this seek type and any slower seek types in its seek speed algorithm. When the bit is set to 0, the drive is not allowed to 
use this seek type in its seek speed algorithm unless a faster seek type is selected. If all JIT bits are set to zero or if all bits are set to one, the drive 
can use any of the seek speeds. 


COMMAND AGING LIMIT field 


The COMMAND AGING LIMIT field specifies the maximum time, in milliseconds, that a command is allowed to languish in the command queue 
before it is marked as the next command to be processed. 
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5.3.34 
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Seagate Specific Unit Attention parameters page (00h) for SSD 


The Seagate Specific Unit Attention parameters page is the last page to be reported by the drive. 
















































































Table 435 Seagate Specific Unit Attention parameters page (00h) for SSD 
Bit 7 6 5 4 3 2 1 0 
Byte 

0 PS SPF (0b) PAGE CODE (00h) 

1 PAGE LENGTH (0Ah) 

2 Reserved Reserved INQUIRY LENGTH | UNIT ATTENTION Reserved ROUND STRICT SCSI-2 
3 Reserved 

4 Reserved 

5 Reserved 

6 Reserved TTE 
7 Reserved 

8 Reserved 

9 Reserved 
10 Reserved 
11 Reserved 














PS (Parameter Savable) bit 

A Parameter Savable (PS) bit of one indicates that the drive is capable of saving the page in a nonvolatile vendor-specific location (used only 
with MODE SENSE command). 

SPF bit 

The SPF bit is described in 5.2.2 and shall be set as shown in table 435. 


PAGE CODE field 
The PAGE CODE field is defined in SPC-5 and shall be set to the value defined in table 435. 


PAGE LENGTH field 


The PAGE LENGTH field specifies the length in bytes of the mode parameters that follow. If the initiator does not set this value to the value that 
is returned for the page by the MODE SENSE command, the drive shall terminate the command with CHECK CONDITION status. The sense key 
shall be set to ILLEGAL REQUEST with the additional sense code set to Invalid Field In Parameter List. See STRICT bit set to 0 description for 
exceptions. 
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IL (INQUIRY Length) bit 


1 When the INQUIRY Length (IL) bit is set to one, the standard INQUIRY data available to a host is limited to the 36 bytes required by the 
SCSI-2 specification. 


0 When the IL bit is set to zero, 148 bytes of standard INQUIRY data are available. The Additional Length field in byte 4 of the INQUIRY data 
is updated to reflect the actual number of additional bytes available. 
UNIT ATTENTION bit 


1 When the UNIT ATTENTION bit is set to one, then UNIT ATTENTION is logged in sense only; no CHECK CONDITION status is presented fol- 
lowing any reset. 


0 When this bit is set to zero, then Check Condition is presented for all affected initiators following a reset until REQUEST SENSE is issued 
by each initiator (as per current operation). 
ROUND bit 
1 When the ROUND bit is set to one, the drive treats and reports rounded parameters as described in 2.3. 
0 When ROUND is set to zero, the drive shall round the parameter and handle command completion reporting as if the parameter had not 
been rounded. 
STRICT bit 


1 When the STRICT bit is set to one, the drive checks for initiator attempts to change unchangeable parameters. If the drive detects an 
attempt, it rejects the command in the standard way, i.e., CHECK CONDITION status from drive, REQUEST SENSE from the initiator, and 
Illegal Request Sense key (Sh) back from the drive. 


0 When the STRICT bit is set to zero, the drive ignores the values of the unchangeable parameters in a MODE SELECT command. The drive 
does not reject the command trying to change unchangeable parameters or trying to send a mode page that is shorter than the sup- 
ported length. 


Caution: — Utilization of this forgiving option by a SCSI initiator port that does not analyze the impact of the truncation could adversely 
affect data integrity. 
SCSI-2 bit 
1 When set to one, the SCSI-2 bit changes the following SCSI-3 features from their SCSI-3 definition to the SCSI-2 definition: 
a) Control Mode Page (OAh) Length from OAh to 06h; and 
b) Caching Page (08h) Length from 12h to OAh. 


Q When S2 is set to zero, all features remain as specified in other portions of this specification. 


TTE (Thermal Throttle Enable) bit 
1 If set to 1, drive activity is limited based on temperature. 


0 ‘If set to 0, drive activity is not limited-based on temperature. 
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5.3.35 Verify Error Recovery mode page (07h) 


The Verify Error Recovery mode page (see table 436) specifies the error recovery parameters the device server shall use during 
the VERIFY command and the verify operation of the WRITE AND VERIFY command. 


Table 436 Verify Error Recovery mode page 













































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PS SPF (0b) PAGE CODE (07h) 
1 PAGE LENGTH (0Ah) 
ERROR RECOVERY BITS 

2 Reserved 

EER PER DTE DCR 
3 VERIFY RETRY COUNT 
4 Obsolete 
5 Reserved formerly 
eee HEAD OFFSET COUNT (Byte 5), DATA STROBE OFFSET COUNT (Byte 6) and WRITE 
9 RETRY COUNT (Byte 8) Bytes 7 and 9 were Reserved 
10 (MSB) 

VERIFY RECOVERY TIME LIMIT —— 

11 (LSB) 





PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field and PAGE LENGTH field 

The parameters saveable (PS) bit, the subpage format (SPF) bit, the PAGE CODE field, the SUBPAGE CODE field, and the PAGE LENGTH field are 
defined in 5.3.5. 

EER bit, PER bit, DTE bit, and DCR bit 

The EER bit, the PER bit, the DTE bit, and the DCR bit (i.e., the error recovery bits) are defined in 5.3.22. The combinations of these bits are 
defined in table 405. 

VERIFY RETRY COUNT field 

The VERIFY RETRY COUNT field specifies the number of times that the device server shall attempt its recovery algorithm during a verify opera- 
tion. 

VERIFY RECOVERY TIME LIMIT field 


The VERIFY RECOVERY TIME LIMIT field specifies in milliseconds the maximum time duration that the device server shall use error recovery pro- 
cedures to recover data for an individual command. The device server may round this value as described in 2.3. 


When both a retry count and a recovery time limit are specified, the one that requires the least time for data error recovery 
actions shall have priority. 


To disable all types of correction and retries the application client should set the EER bit to zero, the PER bit to one, the DTE bit to 
one, the DCR bit to one, the VERIFY RETRY COUNT field to 00h, and the VERIFY RECOVERY TIME LIMIT field to 0000h. 
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5.4 Vital product data parameters 


5.4.1 Vital product data parameters overview and page codes 


This subclause describes the vital product data (VPD) page structure and the VPD pages (see table 437) that are applicable to all 
SCSI devices. These VPD pages are returned by an INQUIRY command with the EVPD bit set to one (see 3.6) and contain vendor 
specific product information about a logical unit and SCSI target device. The vital product data may include vendor 
identification, product identification, unit serial numbers, device operating definitions, manufacturing data, field replaceable 
unit information, and other vendor specific information. 


Table 437 ‘Vital product data page codes 










































































Page code VPD Page Name Reference 
00h Supported VPD Pages 5.4.18 
O1h-7Fh ASCII Information 5.4.2 
80h Unit Serial Number 5.4.19 
83h Device Identification 5.4.11 
84h Software Interface Identification n/s 
85h Management Network Addresses n/s 
86h Extended INQUIRY Data 5.4.9 
87h Mode Page Policy 5.4.14 
88h SCSI Ports 5.4.17 
8Ah Power Condition 5.4.15 
8Bh Device Constituents n/s 
8Ch CFA Profile Information n/s 
8Dh Power Consumption 5.4.16 
BOh Block Limits 5.4.5 
Bih Block Device Characteristics 5.4.3 
B2h Logical Block Provisioning 5.4.13 
B3h Referrals n/s 
B4h Supported Block Lengths and Protection Types n/s 
B5h Block Device Characteristics Extension 5.44 
B6h Zoned Block Device Characteristics 5.4.20 
B7h Block Limits Extension 5.4.6 
COh Firmware Numbers page 5.4.10 
Cth Date Code page 5.4.7 
C2h Jumper Settings page 5.4.12 
C3h Device Behavior page 5.4.8 





n/s = not supported 
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5.4.2 ASCII Information VPD page (01h - 7Fh) 


The ASCII Information VPD page (see table 438) contains information for the field replaceable unit code returned in the sense 
data (see 2.4). 


Table 438 ASCII Information VPD page 



























































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 

1 PAGE CODE (01h - 7Fh) 

2 Reserved 

3 PAGE LENGTH (N-3) 

4 ASCII LENGTH (M-4) 

5 (MSB) 

arers ASCII INFORMATION 

m (LSB) 
m+1 

Vendor specific information 
n 














PERIPHERAL QUALIFIER and the PERIPHERAL DEVICE TYPE fields 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field 
The PAGE CODE field contains the same value as in the PAGE OR OPERATION CODE field of the INQUIRY CDB (see 3.6) and is associated with the 
FIELD REPLACEABLE UNIT CODE field returned in the sense data. 


NOTE The FIELD REPLACEABLE UNIT CODE field in the sense data provides for 255 possible codes, while the 
PAGE CODE field provides for only 127 possible codes. For that reason it is not possible to return ASCII 
Information VPD pages for the upper code values. 


PAGE LENGTH field 


The PAGE LENGTH field specifies the length of the following VPD page data. The relationship between the PAGE LENGTH field and the CDB 
ALLOCATION LENGTH field is defined in 2.2.6. 


ASCII LENGTH field 


The ASCII LENGTH field specifies the length in bytes of the ASCII INFORMATION field that follows. A value of zero in this field indicates that no 
ASCII information is available for the specified page code. The relationship between the ASCII LENGTH field and the CDB ALLOCATION LENGTH 
field is defined in 2.2.6. 


ASCII INFORMATION field 


The ASCII INFORMATION field contains ASCII information concerning the field replaceable unit identified by the page code. The data in this 
field shall be formatted in one or more character string lines. Each line shall contain only graphic codes (i.e., code values 20h through 7Eh) and 
shall be terminated with a NULL (00h) character. 


VENDOR SPECIFIC INFORMATION field 


The contents of the vendor specific information field is not defined in this manual. 
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5.4.3 Block Device Characteristics VPD page (B1h) 


The Block Device Characteristics VPD page (see table 439) contains parameters indicating characteristics of the logical unit. 


Table 439 Block Device Characteristics VPD page 
















































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 

1 PAGE CODE (B1h) 

2 (MSB) 

PAGE LENGTH (003Ch) 
3 (LSB) 
4 (MSB) 
MEDIUM ROTATION RATE 

5 (LSB) 

6 PRODUCT TYPE 

7 WABEREQ WACEREQ NOMINAL FORM FACTOR 

8 Reserved ZONED Reserved BOCS FUAB VBULS 

9 

eae Reserved 

63 











PERIPHERAL QUALIFIER and PERIPHERAL DEVICE TYPE fields 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in SPC-5. 


PAGE CODE and PAGE LENGTH fields 
The PAGE CODE field and PAGE LENGTH field are defined in SPC-5 and shall be set to the values shown in Table 439. 


MEDIUM ROTATION RATE field 
The MEDIUM ROTATION RATE field is defined in Table 440. 


Table 440 Medium Rotation Rate field 











Code Definition 
0000h Medium rotation rate is not reported 
0001h Non-rotating medium (e.g., solid state) 





0002h to 0400h_ ‘| Reserved 


Nominal medium rotation rate in revolutions per minute 
(e.g., 7 200 rpm = 1C20h,10 000 rpm = 2710h, and 15 000 rpm = 3A98h) 





0401h to FFFEh 








FFFFh Reserved 











PRODUCT TYPE field 
The PRODUCT TYPE field (see table 441) defines the product type of the storage device. 
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Table 441 ‘Product Type field 



































Code Definition 

00h Not indicated 

Oth CFast™ (see CFast) 

02h CompactFlash® (see CF) 

03h Memory Stick™ (see MS) 

04h MultiMediaCard (see ee¢MMC) 

05h Secure Digital Card (see SD Card) 

06h XQD™ (see XQD) 

07h Universal Flash Storage (see UFS) 
08h to EFh Reserved 
FOh to FFh Vendor specific 














WABEREQ field 


If a write medium operation has not been performed on a logical block referenced by a mapped LBA since a sanitize block erase operation was 
performed, and no other error occurs during the processing of a read command specifying that LBA, then the write after block erase required 
(WABEREQ) field indicates the device server behavior (see table 442). 


Table 442 WABEREQ field 





Code Definition 

00b Not specified 

O1b The device server completes the read command specifying that LBA with GOOD status and any data 
transferred to the Data-In Buffer is indeterminate. 


10b The device server terminates the read command specifying that LBA with CHECK CONDITION status with 
sense key set to MEDIUM ERROR and the additional sense code set to an appropriate value other than WRITE 
AFTER SANITIZE REQUIRED (e.g., ID CRC OR ECC ERROR). 


11b The device server terminates the read command specifying that LBA with CHECK CONDITION status with 
sense key set to MEDIUM ERROR and the additional sense code set to WRITE AFTER SANITIZE REQUIRED. 


























WACEREQ field 


If a write medium operation has not been performed on a logical block referenced by a mapped LBA since a sanitize cryptographic erase oper- 
ation was performed, and no other error occurs during the processing of a read command specifying that LBA, then the write after cryp- 
tographic erase required (WACEREQ) field indicates the device server behavior (see table 443). 


Table 443. WACEREQ field 





Code Definition 











00b Not specified 

01b The device server completes the read command specifying that LBA with GOOD status and any data 
transferred to the Data-In Buffer is indeterminate. 

10b The device server terminates the read command specifying that LBA with CHECK CONDITION status with 


sense key set to MEDIUM ERROR and the additional sense code set to an appropriate value other than WRITE 
AFTER SANITIZE REQUIRED (e.g., ID CRC OR ECC ERROR). 


11b The device server terminates the read command specifying that LBA with CHECK CONDITION status with 
sense key set to MEDIUM ERROR and the additional sense code set to WRITE AFTER SANITIZE REQUIRED. 

















NOMINAL FORM FACTOR field 
The NOMINAL FORM FACTOR field indicates the nominal form factor of the device containing the logical unit and is defined in Table 444. 
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Table 444 Nominal Form Factor Field 






































Code Definition 

Oh Nominal form factor is not reported 
th 5.25 inch 
2h 3.5 inch 
3h 2.5 inch 
4h 1.8 inch 
5h Less than 1.8 inch 

All others Reserved 

ZONED field 


The ZONED field indicates the type of zoned block capabilities implemented by the device server as defined in table 445. 


Table 445 ZONED field 





























Code Definition 
00b Not reported 
O1b Device server implements the host aware zoned block device capabilities defined in ZBC (see ZBC) 
10b Device server implements device managed zoned block device capabilities 
11b Reserved 
BOCS bit 
1 A BOCS bit set to one indicates that Background Operation Control is supported as described in 5.3.8 
0  ABOCS bit set to zero indicates that Background Operation Control is not supported. 
FUAB bit 
1 A FUAB bit set to one indicates that the device server interprets the SYNCHRONIZE CACHE command and the FUA bit in read commands 
and write commands in compliance with this standard. 
QO =A FUAB bit set to zero indicates that the device server interprets the SYNCHRONIZE CACHE command and the FUA bit in read commands 
and write commands in compliance with SBC-2. 
VBULS bit 
1 A VBULS bit set to one indicates that the device server supports unmapped LBAs while processing VERIFY commands (see 3.55, 3.56, 
3.57, and 3.58) and WRITE AND VERIFY commands (see 3.64, 3.65, 3.66, and 3.67) with the BYTCHK field set to 01b. 
0 A VBULS bit set to zero indicates that the device server does not support unmapped LBAs while processing VERIFY commands and 


WRITE AND VERIFY commands with the BYTCHK field set to 01b. 
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5.4.4 Block Device Characteristics Extension VPD page (B5h) 


The Block Device Characteristics Extension VPD page (see table 446) contains parameters indicating characteristics of the logical 
unit. 


Table 446 _ Block Device Characteristics Extension VPD page 













































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 

1 PAGE CODE (B5h) 

2 (MSB) 

PAGE LENGTH (007Ch) 

3 (LSB) 

4 Reserved 

5 UTILIZATION TYPE 

6 UTILIZATION UNITS 

7 UTILIZATION INTERVAL 

8 (MSB) 

UTILIZATION B 
11 (LSB) 
12 (MSB) 
UTILIZATION A 

15 (LSB) 
16 
see Reserved 
127 














PERIPHERAL QUALIFIER field 
The PERIPHERAL QUALIFIER field is defined in SPC-5. 


PAGE CODE field, PERIPHERAL DEVICE TYPE field, and PAGE LENGTH field 

The PAGE CODE field, PERIPHERAL DEVICE TYPE field, and PAGE LENGTH field are defined in SPC-5 and shall be set to the values shown in table 
446 for the Block Device Characteristics Extension VPD page. 

UTILIZATION TYPE field 


The UTILIZATION TYPE field (see table 447) indicates the designed utilization characteristics for the direct access block device based on the 
contents of the UTILIZATION A field and the UTILIZATION B field evaluated using the units indicated by the UTILIZATION UNITS field over the 
time interval indicated by the UTILIZATION INTERVAL field. 


Table 447 ~—_ UTILIZATION TYPE field 








Code Definition 
Combined writes and reads: the UTILIZATION A field contains designed number of host 
Oth requested bytes transferred by write operations and host requested bytes transferred 


by read operations. The UTILIZATION B field is reserved. 





02h Writes only: the UTILIZATION A field contains designed number of host requested bytes 
transferred by write operations. The UTILIZATION B field is reserved. 





Separate writes and reads: the UTILIZATION A field contains designed number of host 
03h requested bytes transferred by write operations. The UTILIZATION B field contains 
designed number of host requested bytes transferred by read operations. 











All others Reserved 
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UTILIZATION UNITS field 


The UTILIZATION UNITS field (see table 448) indicates the units of measure for the values, if any, in the UTILIZATION A field and the 
UTILIZATION B field. 


Table 448 — UTILIZATION UNITS Field 























Code Definition 
02h megabytes 
03h gigabytes 
04h terabytes 
O5h petabytes 
06h exabytes 
All others Reserved 














UTILIZATION INTERVAL field 


The UTILIZATION INTERVAL field (see table 449) indicates a nominal calendar time reference interval over which the values, if any, in the 
UTILIZATION A field and the UTILIZATION B field may be applied. 


Table 449 ~~ UTILIZATION INTERVAL Field 











Code Definition 
OAh per day 
OEh per year 
All others Reserved 














UTILIZATION A field and the UTILIZATION B field 

The UTILIZATION A field and the UTILIZATION B field indicate the designed utilization characteristics for the direct access block device as: 
a) defined by the utilization type field; 
b) expressed in the units defined by the utilization units field; and 
c) over the time interval defined by the utilization interval field. 
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5.4.5 Block Limits VPD page (BOh) 


The Block Limits VPD page (see table 450) provides the application client with the means to obtain certain operating parameters 
of the logical unit. 


Table 450 Block Limits VPD page (Sheet 1 of 2) 





















































































































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 
1 PAGE CODE (BOh) 
2 (MSB) 
PAGE LENGTH (003Ch) 
3 (LSB) 
4 Reserved WSNZ 
5 MAXIMUM COMPARE AND WRITE LENGTH 
6 (MSB) 
OPTIMAL TRANSFER LENGTH GRANULARITY 
7 (LSB) 
8 (MSB) 
scais MAXIMUM TRANSFER LENGTH 
11 (LSB) 
12 (MSB) 
ieee OPTIMAL TRANSFER LENGTH 
15 (LSB) 
16 (MSB) 
wee MAXIMUM PREFETCH LENGTH 
19 (LSB) 
20 (MSB) 
wee MAXIMUM UNMAP LBA COUNT 
23 (LSB) 
24 (MSB) 
oe MAXIMUM UNMAP BLOCK DESCRIPTOR COUNT 
27 (LSB) 
28 (MSB) 
aise OPTIMAL UNMAP GRANULARITY 
31 (LSB) 
32 UGAVALID (MSB) 
Se UNMAP GRANULARITY ALIGNMENT 
35 (LSB) 
36 (MSB) 
skis MAXIMUM WRITE SAME LENGTH 
43 (LSB) 
44 (MSB) 
oes MAXIMUM ATOMIC TRANSFER LENGTH 
47 (LSB) 
48 (MSB) 
ies ATOMIC ALIGNMENT 
51 (LSB) 
52 (MSB) 
arate ATOMIC TRANSFER LENGTH GRANULARITY 
55 (LSB) 
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Table 450 Block Limits VPD page (Sheet 2 of 2) 
Bit 7 6 5 0 
Byte 
56 (MSB) 
secs MAXIMUM ATOMIC TRANSFER LENGTH WITH ATOMIC BOUNDARY 
59 (LSB) 
60 (MSB) 
wee MAXIMUM ATOMIC BOUNDARY SIZE 
63 (LSB) 














PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in SPC-5. 


PAGE CODE field and PAGE LENGTH field 

The PAGE CODE field and PAGE LENGTH field are defined in SPC-5 and shall be set to the values shown in table 450 for the Block Limits VPD 
page. 

WSNZ bit 


1 A write same non-zero (WSNZ) bit set to one indicates that the device server does not support a value of zero in the NUMBER OF LOGI- 
CAL BLOCKS field in the WRITE SAME command CDBs (see 3.73, 3.74, and 3.75). 


0 AWSNZ bit set to zero indicates that the device server may or may not support a value of zero in the NUMBER OF LOGICAL BLOCKS field 
of the WRITE SAME commands. 


MAXIMUM COMPARE AND WRITE LENGTH field 


A MAXIMUM COMPARE AND WRITE LENGTH field set to a non-zero value indicates the maximum value that the device server accepts in the 
NUMBER OF LOGICAL BLOCKS field in the COMPARE AND WRITE command (see SBC-4). A MAXIMUM COMPARE AND WRITE LENGTH field set to 
zero indicates that the device server does not support the COMPARE AND WRITE command. The device server shall set the MAXIMUM COM- 
PARE AND WRITE LENGTH field to a value less than or equal to the value in the MAXIMUM TRANSFER LENGTH field. 


OPTIMAL TRANSFER LENGTH GRANULARITY field 


The OPTIMAL TRANSFER LENGTH GRANULARITY field set to a non-zero value indicates the optimal transfer length granularity size in logical 
blocks for a single command shown in the command column of table 451. If a device server receives one of these commands with a transfer 
size that is not equal to a multiple of this value, then the device server may incur significant delays in processing the command. An OPTIMAL 
TRANSFER LENGTH GRANULARITY field set to 0000_0000h indicates that the device server does not report optimal transfer length granularity. 
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Table 451 _—‘ Transfer limits for commands 
: ae Block Limits VPD page Additional sense code if the 
Command Bee eecloee field(s) that indicate value in the specified field 
maximum limits exceeds the maximum limit 
CDB NUMBER OF MAXIMUM COMPARE AND 
COMPARE AND WRITE LOGICAL BLOCKS field WRITE LENGTH field 
CDB TRANSFER MAXIMUM TRANSFER 
ORWRITE (16) / (32) LENGTH field LENGTH field 
CDB PREFETCH MAXIMUM PREFETCH 
PREFETCH (10) / (16) LENGTH field LENGTH field 
CDB TRANSFER 
READ (10) / (12) / (16) / (32) LENGTH field INVALDIN FIELD IN CDB 
CDB VERIFICATION 
VERIFY (10) / (12) / (16) / (32) rENGTH fald 
MAXIMUM TRANSFER 
WRITE (10) / (12) / (16) / (32) LENGTH field 
READ (10) / (12) / (16) / (32) CDB TRANSFER 
XDWRITEREAD (10) / (32) LENGTH field 
XPWRITE (10) / (32) 
Any individual block device range 
descriptor ina POPULATE TOKEN Block device range 
command (see SBC-4) descriptor NUMBER MAXIMUM TRANSFER INVALID FIELD IN 
| Any individual block device range | | OF LOGICAL BLOCKS LENGTH field PARAMETER LIST 
descriptor in a WRITE USING TOKEN field 
command (see SBC-4) 




















MAXIMUM TRANSFER LENGTH field 


The MAXIMUM TRANSFER LENGTH field set to a non-zero value indicates the maximum transfer length in logical blocks that the device server 
accepts for a single command shown in table 450. If a device server receives one of these commands with a transfer size greater than this value, 
then the device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the addi- 
tional sense code set to the value shown in table 451. A MAXIMUM TRANSFER LENGTH field set to 0000_0000h indicates that the device server 
does not report a limit on the transfer length. 


OPTIMAL TRANSFER LENGTH field 


The OPTIMAL TRANSFER LENGTH field set to a non-zero value indicates the optimal transfer size in logical blocks for a single command shown 
in table 450. If a device server receives one of these commands with a transfer size greater than this value, then the device server may incur sig- 
nificant delays in processing the command. An OPTIMAL TRANSFER LENGTH field set to 0000_0000h indicates that the device server does not 
report an optimal transfer size. 


MAXIMUM PREFETCH LENGTH field 


The MAXIMUM PREFETCH LENGTH field indicates the maximum prefetch length in logical blocks that the device server accepts for a single 
PRE-FETCH command. The device server should set the MAXIMUM PREFETCH LENGTH field to less than or equal to the MAXIMUM TRANSFER 
LENGTH field. 
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MAXIMUM UNMAP LBA COUNT field 


The MAXIMUM UNMAP LBA COUNT field set to a non-zero value indicates the maximum number of LBAs that may be unmapped by an UNMAP 
command (see 3.54). If the number of LBAs that may be unmapped by an UNMAP command is constrained only by the amount of data that 
may be contained in the UNMAP parameter list (see 3.54.2), then the device server shall set the MAXIMUM UNMAP LBA COUNT field to 
FFFF_FFFFh. lf the device server implements the UNMAP command, then the value in this field shall be greater than or equal to one. A MAXI- 
MUM UNMAP LBA COUNT field set to 0000_0000h indicates that the device server does not implement the UNMAP command. 


MAXIMUM UNMAP BLOCK DESCRIPTOR COUNT field 


The MAXIMUM UNMAP BLOCK DESCRIPTOR COUNT field set to a non-zero value indicates the maximum number of UNMAP block descriptors 
(see 3.54.2) that shall be contained in the parameter data transferred to the device server for an UNMAP command (see 3.54). If there is no limit 
on the number of UNMAP block descriptors contained in the parameter data, then the device server shall set the MAXIMUM UNMAP BLOCK 
DESCRIPTOR COUNT field to FFFF_FFFFh. If the device server implements the UNMAP command, then the value in the MAXIMUM UNMAP 
BLOCK DESCRIPTOR COUNT field shall be greater than or equal to one. A MAXIMUM UNMAP BLOCK DESCRIPTOR COUNT field set to 
0000_0000h indicates that the device server does not implement the UNMAP command. 


OPTIMAL UNMAP GRANULARITY field 


The OPTIMAL UNMAP GRANULARITY field set to a non-zero value indicates the optimal granularity in logical blocks for unmap requests (e.g., an 
UNMAP command or a WRITE SAME (16) command with the UNMAP bit set to one). An unmap request with a number of logical blocks that is 
not a multiple of this value may result in unmap operations on fewer LBAs than requested. An OPTIMAL UNMAP GRANULARITY field set to 
0000_0000h indicates that the device server does not report an optimal unmap granularity. 


UGVALID bit 


1 An UGVALID (unmap granularity alignment valid) bit set to one indicates that the UNMAP GRANULARITY ALIGNMENT field is valid. 
0 A UGAVALID bit set to zero indicates that the UNMAP GRANULARITY ALIGNMENT field is not valid. 


UNMAP GRANULARITY ALIGNMENT field 


The UNMAP GRANULARITY ALIGNMENT field indicates the LBA of the first logical block to which the OPTIMAL UNMAP GRANULARITY field 
applies. The unmap granularity alignment is used to calculate an optimal unmap request starting LBA as follows: 


optimal unmap request starting LBA = (n x optimal unmap granularity) + unmap granularity alignment 


where: 
n is Zero or any positive integer value; 
optimal unmap granularity is the value in the OPTIMAL UNMAP GRANULARITY field; and 
unmap granularity alignment is the value in the UNMAP GRANULARITY ALIGNMENT field. 


An unmap request with a starting LBA that is not optimal may result in unmap operations on fewer LBAs than requested. 


MAXIMUM WRITE SAME LENGTH field 


A MAXIMUM WRITE SAME LENGTH field set to a non-zero value indicates the maximum value that the device server accepts in the NUMBER OF 
LOGICAL BLOCKS field for a WRITE SAME command. A MAXIMUM WRITE SAME LENGTH field set to zero indicates that the device server does 
not report a limit on the number of logical blocks that may be requested for a single WRITE SAME command. 


MAXIMUM ATOMIC TRANSFER LENGTH field 


If the ATOMIC BOUNDARY field in the CDB (see 3.68 and 3.69) is set to zero, then a MAXIMUM ATOMIC TRANSFER LENGTH field set to a non-zero 
value indicates the maximum atomic transfer length in logical blocks that the device server supports for a single atomic write command (see 
3.68 and 3.69) AMAXIMUM ATOMIC TRANSFER LENGTH field set to 0000_0000h indicates that the device server does not indicate a maximum 
atomic transfer length. The maximum atomic transfer length indicated by the MAXIMUM ATOMIC TRANSFER LENGTH field shall be less than or 
equal to the maximum transfer length indicated by the MAXIMUM TRANSFER LENGTH field. The maximum atomic transfer length indicated by 
the MAXIMUM ATOMIC TRANSFER LENGTH field shall be a multiple of the value in the ATOMIC TRANSFER LENGTH GRANULARITY field. If the 
ATOMIC BOUNDARY field in the CDB is set to a non-zero value, then the MAXIMUM ATOMIC TRANSFER LENGTH field is ignored. 
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ATOMIC ALIGNMENT field 


The ATOMIC ALIGNMENT field indicates the required alignment of the starting LBA in an atomic write command. If the ATOMIC ALIGNMENT 
field is set to 0000_0000h, then there is no alignment requirement for atomic write commands. 


If the ATOMIC ALIGNMENT field is non-zero, then the starting LBA of an atomic write request shall meet the following: 
atomic request starting LBA = n x atomic alignment 
where: 
n is zero or any positive integer value; and 


atomic alignment is the value in the ATOMIC ALIGNMENT field, 


ATOMIC TRANSFER LENGTH GRANULARITY field 


The ATOMIC TRANSFER LENGTH GRANULARITY field indicates the minimum transfer length for a WRITE ATOMIC command. Atomic write oper- 
ations are required to have a transfer length that is a multiple of the atomic transfer length granularity. An ATOMIC TRANSFER LENGTH GRANU- 
LARITY field set to 0000_0000h indicates that there is no atomic transfer length granularity requirement. 


ATOMIC BOUNDARY field 


If the ATOMIC BOUNDARY field in the CDB (see 3.68 and 3.69) is set to a non-zero value, then a MAXIMUM ATOMIC TRANSFER LENGTH WITH 
ATOMIC BOUNDARY field set to a non-zero value indicates the maximum transfer length in logical blocks that the device server supports for a 
single atomic write command (see SBC-4). A MAXIMUM ATOMIC TRANSFER LENGTH WITH ATOMIC BOUNDARY field set to 0000_0000h indi- 
cates that the device server does not indicate a maximum atomic transfer length with atomic boundary. The maximum atomic transfer length 
with atomic boundary indicated by the MAXIMUM ATOMIC TRANSFER LENGTH WITH ATOMIC BOUNDARY field shall be less than or equal to the 
maximum transfer length indicated by the MAXIMUM TRANSFER LENGTH field. The maximum atomic transfer length with atomic boundary 
indicated by the MAXIMUM ATOMIC TRANSFER LENGTH WITH BOUNDARY field shall be a multiple of the value in the ATOMIC TRANSFER 
LENGTH GRANULARITY field. If the ATOMIC BOUNDARY field in the CDB is set to zero, then the MAXIMUM ATOMIC TRANSFER LENGTH WITH 
ATOMIC BOUNDARY field is ignored. 


MAXIMUM ATOMIC BOUNDARY SIZE field 


A MAXIMUM ATOMIC BOUNDARY SIZE field set to a non-zero value indicates that the device server supports atomic write commands perform- 
ing more than one atomic operation. The maximum atomic boundary size indicates the maximum number of logical blocks on which the 
device server is able to perform atomic operations (see SBC-4). A MAXIMUM ATOMIC BOUNDARY SIZE field set to 0000h indicates that the 
device server does not support atomic write commands performing more than one atomic operation. The MAXIMUM ATOMIC BOUNDARY SIZE 
field shall be a multiple of the value in the ATOMIC TRANSFER LENGTH GRANULARITY field. 
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5.4.6 Block Limits Extension VPD page (B7h) 


The Block Limits Extension VPD page (see table 452) provides the application client with the means to obtain certain operating parameters of 
the logical unit. 


Table 452 Block Limits Extension VPD page 















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 

1 PAGE CODE (B7h) 

2 (MSB) 

PAGE LENGTH (n-4) 
3 (LSB) 
4 
Reserved 
5 
6 (MSB) 
MAXIMUM NUMBER OF STREAMS 
7 (LSB) 
8 (MSB) 
OPTIMAL STREAM WRITE SIZE 
9 (LSB) 
10 (MSB) 
ait STREAM GRANULARITY SIZE 
13 (LSB) 
14 
Reserved 
n 








PERIPHERAL QUALIFIER and PERIPHERAL DEVICE TYPE fields 
The PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field are defined in SPC-5. 


PAGE CODE field and PAGE LENGTH field 


The PAGE CODE field and PAGE LENGTH field are defined in SPC-5 and shall be set to the values shown in table 452 for the Block Limits Exten- 
sion VPD page. 


MAXIMUM NUMBER OF STREAMS field 


The MAXIMUM NUMBER OF STREAMS field indicates the maximum number of streams that the device server supports and the maximum value 
for the stream identifier plus one. A maximum number of streams field set to 0000h indicates that the device server does not support Stream 
Control. 


OPTIMAL STREAM WRITE SIZE field 


The OPTIMAL STREAM WRITE SIZE field indicates the alignment and size of the optimal stream write as a number of logical blocks. The optimal 
stream write size is the same for all streams in the device server. 


STREAM GRANULARITY SIZE field 
The STREAM GRANULARITY SIZE field indicates the stream granularity size in number of optimal stream write size blocks as described in 3.50. 
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5.4.7 Date Code page (Cth) 
Table 453. ETF Log Date Code page (C1h) 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 ‘GUMIFIEN PERIPHERAL DEVICE TYPE 
1 PAGE CODE (C1h) 
2 00h 
3 PAGE LENGTH (10h) 
4 (MSB) 
oe ETF LOG DATE IN ASCII 
11 (LSB) 
12 (MSB) 
COMPILE DATE CODE 
19 (LSB) 
20 
a LAST SPINDOWN POWER CYCLE COUNT 
22 (MSB) 
LAST SPINDOWN TIMESTAMP 
27 (LSB) 











PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field 
The PAGE CODE field shall be set to the value defined in table 453. 


PAGE LENGTH field 


The PAGE LENGTH field specifies the length of the following VPD page data. The relationship between the PAGE LENGTH field and the CDB 
ALLOCATION LENGTH field is defined in 2.2.6. 


ETF Log field 


The ETF Log date code field contains ASCII data. The data is stored in the format MMDDYYYY. Leading ASCII zero characters are added to sin- 
gle-digit months or days. 


COMPILE DATE CODE field 
The COMPILE DATE CODE field contains 8 ASCII bytes of data for a date of the form MMDDYYYY. 


LAST SPINDOWN POWER CYCLE COUNT field 
The LAST SPINDOWN POWER CYCLE COUNT field contains the power cycle count saved at the last spin down. 


LAST SPINDOWN TIMESTAMP field 
The LAST SPINDOWN TIMESTAMP field contains the timestamp saved at the last spin down. 
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5.4.8 Device Behavior page (C3h) 


The Device Behavior page (see table ) will be used by the regression tests to determine what behavior should be expected from 
a particular firmware package. 


Table 454 Device Behavior page (C3h) 

































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 

1 PAGE CODE (C3h) 

2 Reserved 

3 PAGE LENGTH 

4 VERSION NUMBER 

5 BEHAVIOR CODE 

6 BEHAVIOR CODE VERSION NUMBER 

7 

ASCII FAMILY NUMBER (16 bytes) 

22 

23 NUMBER OF INTERLEAVES 

24 DEFAULT NUMBER OF CACHE SEGMENTS 
25+ Feature Flags and Additional Byte Fields will go here but are undefined at this time. 








PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE fields 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field 
The PAGE CODE field shall be set to the value defined in table 454. 


PAGE LENGTH field 

PAGE LENGTH defines the length of the Device Behavior information in bytes. If the ALLOCATION LENGTH is too small to transfer all of the page, 
the page length shall not be adjusted to reflect the truncation. 

VERSION NUMBER field 

The VERSION NUMBER is a one-byte short form notation for the 24-byte assignment in the Firmware Numbers page. Version Numbers are reg- 
istered by Engineering services. 

BEHAVIOR CODE and BEHAVIOR CODE VERSION NUMBER fields 

The BEHAVIOR CODE and BEHAVIOR CODE VERSION NUMBER are jointly assigned by the Firmware Engineering Managers of all SCSI design 
locations. 

ASCII FAMILY NUMBER field 

The ASCII FAMILY NUMBER field contains the drive model number. The data is left-aligned within this field. 


NUMBER OF INTERLEAVES field 
The NUMBER OF INTERLEAVES field indicates the number of data interleaves used by the ECC correction algorithm. 


DEFAULT NUMBER OF CACHE SEGMENTS field 
The DEFAULT NUMBER OF CACHE SEGMENTS field gives the number of segments into which the host requests the drive divide the cache. 
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5.4.9 Extended INQUIRY Data VPD page (86h) 
The Extended INQUIRY Data VPD page (see table 455) provides the application client with a means to obtain information about the logical unit. 


Table 455 Extended INQUIRY Data VPD page 




























































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 
1 PAGE CODE (86h) 
2 (MSB) 
PAGE LENGTH (3Ch) 
3 (LSB) 
4 ACTIVATE MICROCODE SPT GRD_CHK APP_CHK REF_CHK 
5 Reserved UASK_SUP GROUP_SUP PRIOR_SUP HEADSUP ORDSUP SIMPSUP 
6 Reserved WU_SUP CRD_SUP NV_SUP V_SUP 
7 Reserved NO_PI_CHK P_|_|_SUP Reserved LUICLR = 1 
8 Reserved R_SUP Reserved RTD_SUP HSSRELEF Obsolete 
9 Reserved MULTI 1_T NEXUS MICROCODE DOWNLOAD 
10 (MSB) 
EXTENDED SELF-TEST COMPLETION MINUTES 
11 (LSB) 
12 POA_SUP HRA_SUP VSA_SUP Reserved 
13 MAXIMUM SUPPORTED SENSE DATA LENGTH 
14 
ese Reserved 
63 











PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field 
The PAGE CODE field shall be set to the value defined in table 455. 


PAGE LENGTH field 


The PAGE LENGTH field specifies the length of the following VPD page data and shall be set to 60. The relationship between the PAGE LENGTH 
field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 


ACTIVATE MICROCODE field 


The ACTIVATE MICROCODE field (see table 456) indicates how a device server activates microcode and establishes a unit attention condition 
when a WRITE BUFFER command (see 3.70) with the download microcode mode set to 05h or 07h is processed. 
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Table 456 ACTIVATE MICROCODE field 

















Value Meaning 
00b The actions of the device server may or may not be as defined for values 01b or 10b. 
The device server: 
1) activates the microcode before completion of the final command in the WRITE BUFFER sequence; and 
O1b 2) establishes a unit attention condition for the initiator port associated with every |_T nexus, except the 
|_T nexus on which the WRITE BUFFER command was received, with the additional sense code set to 
MICROCODE HAS BEEN CHANGED. 
The device server: 
1) activates the microcode after: 
A) avendor specific event; 
10b B) a power on event; or 
C) a hard reset event; 
and 
2) establishes a unit attention condition for the initiator port associated with every I_T nexus with the 
additional sense code set to MICROCODE HAS BEEN CHANGED. 
11b Reserved. 














SPT (Supported Protection Type) field 


A supported protection type (SPT) field (see table 457) indicates the type of protection the logical unit supports. The SPT field shall be ignored 
if the PROTECT bit is set to zero. 


Table 457 = SPT field 




















Code Definition 

000b The logical unit supports type 1 protection (see SBC-4). 

001b The logical unit supports type 2 protection (see SBC-4). 

010b Reserved 

011b The logical unit supports type 3 protection (see SBC-4). 
100b-111b | Reserved 














GRD_CHK (Guard Check) bit 


0 A guard check (GRD_CHK) bit set to zero indicates that the device server does not check the LOGICAL BLOCK GUARD field in the protec- 
tion information (see SBC-4), if any. 


1 A GRD_CHK bit set to one indicates that the device server checks the LOGICAL BLOCK GUARD field in the protection information, if any. 


APP_CHK (Application Tag Check) bit 


0 An application tag check (APP_CHK) bit set to zero indicates that the device server does not check the LOGICAL BLOCK APPLICATION 
TAG field in the protection information (see SBC-4), if any. 


1 An APP_CHK bit set to one indicates that the device server checks the LOGICAL BLOCK APPLICATION TAG field in the protection informa- 
tion, if any. 
REF_CHK (Reference Tag Check) bit 


0 A reference tag check (REF_CHK) bit set to zero indicates that the device server does not check the LOGICAL BLOCK REFERENCE TAG field 
in the protection information (see SBC-4), if any. 


1 A REF_CHK bit set to one indicates that the device server checks the LOGICAL BLOCK REFERENCE TAG field in the protection information, 
if any. 
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UASK_SUP (Unit Attention Sense Key Supported) bit 


1 A unit attention condition sense key specific data supported (UASK_SUP) bit set to one indicates that the device server returns 
sense-key specific data for the UNIT ATTENTION sense key (see 2.4.1.1.4.6). 


0 AUASK_SUP bit set to zero indicates that the device server does not return sense-key specific data for the UNIT ATTENTION sense key. 


GROUP_SUP (Grouping Function Supported) bit 


1 A grouping function supported (GROUP_SUP) bit set to one indicates that the grouping function (see SBC-4) is supported by the device 
server. 


0 AGROUP_SUP bit set to zero indicates that the grouping function is not supported. 


PRIOR_SUP (Priority Supported) bit 
1 A priority supported (PRIOR_SUP) bit set to one indicates that task priority (see SAM-5) is supported by the logical unit. 
O =A PRIOR_SUP bit set to zero indicates that task priority is not supported. 


HEADSUP (Head of Queue Supported) bit 


1 A head of queue supported (HEADSUP) bit set to one indicates that the HEAD OF QUEUE task attribute (see SAM-5) is supported by the 
logical unit. 


O AHEADSUP bit set to zero indicates that the HEAD OF QUEUE task attribute is not supported. If the HEADSUP bit is set to zero, applica- 
tion clients should not specify the HEAD OF QUEUE task attribute as an Execute Command procedure call argument. 


ORDSUP (Ordered Supported) bit 
1 An ordered supported (ORDSUP) bit set to one indicates that the ORDERED task attribute (see SAM-5) is supported by the logical unit. 


0 AnORDSUP bit set to zero indicates that the ORDERED task attribute is not supported. If the ORDSUP bit is set to zero, application clients 
should not specify the ORDERED task attribute as an Execute Command procedure call argument. 


SIMPSUP (Simple Supported) bit 


1 A simple supported (SIMPSUP) bit set to one indicates that the SIMPLE task attribute (see SAM-5) is supported by the logical unit. Logical 
units that support the full task management model (see SAM-5) shall set the SIMPSUP bit to one. 


0 A SIMPSUP bit set to zero indicates that the SIMPLE task attribute is not supported. If the SIMPSUP bit is set to zero, application clients 
should not specify the SIMPLE task attribute as an Execute Command procedure call argument. 


WU_SUP bit 


0 = Awrite uncorrectable supported (WU_SUP) bit set to zero indicates that the device server does not support application clients setting 
the WR_UNCOR bit to one in the WRITE LONG command (see 3.72). 


1 A WU_SUP bit set to one indicates that the device server supports application clients setting the WR_UNCOR bit to one in the WRITE 
LONG command. 


CRD_SUP bit 


0 = Acorrection disable supported (CRD_SUP) bit set to zero indicates that the device server does not support application clients setting 
the COR_DIS bit to one in the WRITE LONG command (see 3.72). 


1 A CRD_SUP bit set to one indicates that the device server supports application clients setting the COR_DIS bit to one in the WRITE LONG 
command. 


NV_SUP bit 


1 An NV_SUP bit set to one indicates that the device server supports a non-volatile cache and that the applicable command standard 
defines features using this cache. 


O AnNV_SUP bit set to zero indicates that the device server may or may not support a non-volatile cache. 


V_SUP bit 


1 A V_SUP bit set to one indicates that the device server supports a volatile cache and that the applicable command standard defines fea- 
tures using this cache (e.g., the FUA bit in SBC-4). 


0 AnV_SUP bit set to zero indicates that the device server may or may not support a volatile cache. 
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NO_PI_CHK bit 


1 a NO PROTECTION INFORMATION CHECKING (NO_PI_CHK) bit set to one indicates that the device server disables checking of all 
protection information for the associated protection information interval when performing a write operation if: 


a) the LOGICAL BLOCK APPLICATION TAG field is set to FFFFh and type 1 protection (see SBC-4) is enabled; 
b) the LOGICAL BLOCK APPLICATION TAG field is set to FFFFh and type 2 protection (see SBC-4) is enabled; or 


c) the LOGICAL BLOCK APPLICATION TAG field is set to FFFFh, the LOGICAL BLOCK REFERENCE TAG field is set to 
FFFF FFFFh, and type 3 protection (see SBC-4) is enabled. 


0 A NO_PI_CHK bit set to zero indicates that the device server checks protection information as specified by the WRPROTECT field (see 
SBC-4) when performing a write operation. 


P_I_I_SUP bit 


1 A protection information interval supported (P_I_|_SUP) bit set to one indicates that the logical unit supports protection information 
intervals (see SBC-4). 


0 A P_|_I_SUP bit set to zero indicates that the logical unit does not support protection information intervals. 


LUICLR bit 


1 A logical unit |_T nexus clear (LUICLR) bit set to one indicates the SCSI target device clears any unit attention condition with an addi- 
tional sense code of REPORTED LUNS DATA HAS CHANGED in each logical unit accessible to an |_T nexus after reporting the unit atten- 
tion condition for any logical unit over that |_T nexus (see SAM-5). 


0 = An LUICLR bit set to zero indicates the SCSI target device clears unit attention conditions as defined in SPC-5. 
The LUICLR bit shall be set to one. 


R_SUP bit 
0 A referrals supported (R_SUP) bit set to zero indicates that the device server does not support referrals (see SBC-4). 


1 An R_SUP bit set to one indicates that the device server supports referrals. 


RTD_SUP bit 
O AnRTD_SUP bit set to zero indicates that the RTD bit in MODE SELECT commands is not supported. 
1 An RTD bit set to one indicates that the RTD bit in MODE SELECT commands is supported. 


HSSRELEF bit 
1 A HSSRELEF bit set to one indicates the device server implements alternate reset handling for history snapshots. 


0 =A history snapshots release effects (HSSRELEF) bit set to zero indicates the device server implements normal reset handling for history 
snapshots. 


MULTI I_T NEXUS MICROCODE DOWNLOAD field 


The MULTI I_T NEXUS MICROCODE DOWNLOAD field (see SPC-5) indicates how the device server handles concurrent attempts to 
download microcode using the WRITE BUFFER command (see SPC-5) from multiple |_T nexuses. 
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EXTENDED SELF-TEST COMPLETION MINUTES field 


The EXTENDED SELF-TEST COMPLETION MINUTES field contains advisory data that is the time in minutes that the device server 
requires to complete an extended self-test provided the device server is not interrupted by subsequent commands and no 
errors occur during processing of the self-test. The application client should expect the self-test completion time to exceed the 
value in this field if other commands are sent to the logical unit while a self-test is in progress or if errors occur during the 
processing of the self-test. If a device server supports SELF-TEST CODE field values other than 000b for the SEND DIAGNOSTIC 
command (see 3.46) and the self-test completion time is greater than 18 hours, then the device server shall support the 
EXTENDED SELF-TEST COMPLETION MINUTES field. A value of 0000h indicates that the EXTENDED SELF-TEST COMPLETION 
MINUTES field is not supported. A value of FFFFh indicates that the extended self-test takes 65 535 minutes or longer. 


POA_SUP bit 


1 A power on activation supported (POA_SUP) bit set to one indicates that the device server supports a WRITE BUFFER command with the 
MODE field set to ODh (see 3.70.10) and the PO_ACT bit set to one. 


0 APOA_SUP bit set to zero indicates that the device server does not support a WRITE BUFFER command with the MODE field set to ODh 
and the PO_ACT bit set to one. 


HRA_SUP bit 


1 A hard reset activation supported (HRA_SUP) bit set to one indicates that the device server supports a WRITE BUFFER command with 
the MODE field set to ODh (see 3.70.11) and the HR_ACT bit set to one. 


0 A HRA_SUP bit set to zero indicates that the device server does not support a WRITE BUFFER command with the MODE field set to ODh 
and the HR_ACT bit set to one. 


VSA_SUP bit 


1 A vendor specific activation supported (VSA_SUP) bit set to one indicates that the device server supports a WRITE BUFFER command 
with the MODE field set to ODh (see 3.70.10) and the VSE_ACT bit set to one. 


OQ AVSA_SUP bit set to zero indicates that the device server does not support a WRITE BUFFER command with the MODE field set to ODh 
and the VSE_ACT bit set to one. 


MAXIMUM SUPPORTED SENSE DATA LENGTH field 


The MAXIMUM SUPPORTED SENSE DATA LENGTH field indicates the maximum length in bytes of sense data (see 2.4) that the 
device server is capable of returning in the same |_T_L_Q nexus transaction as the status. AMAXIMUM SUPPORTED SENSE DATA 
LENGTH field set to zero indicates that the device server does not report a maximum length. This value shall be less than or equal 
to 252. 


SCSI Commands Reference Manual, Rev. J 487 


www.seagate.com Parameters for direct access devices 






























































5.4.10 Firmware Numbers page (COh) 
Table 458 Firmware Numbers page (COh) 
Bit 7 6 5 4 3 2 1 0 
Byte 
PERIPHERAL 

0 QUALIFIER PERIPHERAL DEVICE TYPE 
1 PAGE CODE (COh) 

2 00h 

3 PAGE LENGTH 

4 
a SCSI FIRMWARE RELEASE NUMBER 

11 

12 
ais SERVO FIRMWARE RELEASE NUMBER 

19 
20 
ee SAP BLOCK POINT NUMBERS (MAJOR/MINOR) 
27 
28 
Ses SERVO FIRMWARE RELEASE DATE 
31 
32 
seis SERVO ROM RELEASE DATE 
35 
36 
sare SAP FIRMWARE RELEASE NUMBER 
43 
44 
tae SAP FIRMWARE RELEASE DATE 
47 
48 
Sats SAP FIRMWARE RELEASE YEAR 
51 
52 
ae SAP MANUFACTURING KEY 
55 
56 
oes SERVO FIRMWARE PRODUCT FAMILY AND PRODUCT FAMILY MEMBER IDs 
59 














PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE fields 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field 
The PAGE CODE field shall be set to the value defined in table 458. 


PAGE LENGTH field 


The PAGE LENGTH field specifies the length of the following VPD page data. The relationship between the PAGE LENGTH field and the CDB 
ALLOCATION LENGTH field is defined in 2.2.6. 
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SCSI FIRMWARE RELEASE NUMBER field 

The SCSI FIRMWARE RELEASE NUMBER fields contain ASCII data. The least significant ASCII character of the Drive firmware number shall appear 
as the last byte of the field. 

SERVO FIRMWARE RELEASE NUMBER field 

The SERVO FIRMWARE RELEASE NUMBER fields contain ASCII data. The least significant ASCII character of the Drive firmware number shall 
appear as the last byte of the field. 

SAP BLOCK POINT NUMBERS (MAJOR/MINOR) 


This field contains the Servo Adaptive Parameter Block Point Number. 


SERVO FIRMWARE RELEASE DATE field 


Servo Firmware Release Date indicates the date of the firmware release. 


SERVO ROM RELEASE DATE field 
Servo ROM Release Date indicates the date of the ROM release. 


SAP FIRMWARE RELEASE NUMBER field, SAP FIRMWARE RELEASE DATE field, and SAP FIRMWARE RELEASE YEAR field 


These fields are created independently from the servo firmware. These fields contain ASCII data. 


SAP MANUFACTURING KEY field 
The SAP MANUFACTURING KEY field contains a binary code used by manufacturing to identify the SAP. 


SERVO FIRMWARE PRODUCT FAMILY and PRODUCT FAMILY MEMBER IDs field 


The high order word of the SERVO FIRMWARE PRODUCT FAMILY and PRODUCT FAMILY MEMBER IDs field contains a binary code which corre- 
sponds to the Servo Firmware Family ID. The low order word of this field contains a binary code which corresponds to the Product Family Mem- 
ber ID. 
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5.4.11 Device Identification VPD page (83h) 


The Device Identification VPD page (see table ) provides the means to retrieve zero or more identification descriptors applying to 
the logical unit. Logical units may have more than one identification descriptor (e.g., if several types or associations of identifier 
are supported). Device identifiers consist of one or more of the following: 


+ Logical unit names; 
+ SCSI target port identifiers; 
- SCSI target port names; 
+ SCSI target device names; 
+ Relative target port identifiers; 
+ SCSI target port group number; or 
+ Logical unit group number. 
Identification descriptors shall be assigned to the peripheral device (e.g., a disk drive) and not to the currently mounted media, in 


the case of removable media devices. Operating systems are expected to use the identification descriptors during system 
configuration activities to determine whether alternate paths exist for the same peripheral device. 


Table 459 _ Device Identification VPD page 






























































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 
1 PAGE CODE (83h) 
2 MSB 
PAGE LENGTH (n-3) 
3 LSB 
Identification descriptor list 
4 
Identification Descriptor (first) (see table 460) 
Identification Descriptor (last) (see table 460) 
n 




















PERIPHERAL QUALIFIER and the PERIPHERAL DEVICE fields 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field 
The PAGE CODE field shall be set to the value defined in table . 


PAGE LENGTH field 


The PAGE LENGTH field specifies the length of the following VPD page data. The relationship between the PAGE LENGTH field and the CDB 
ALLOCATION LENGTH field is defined in 2.2.6. 
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Identification Descriptor field 


Each IDENTIFICATION DESCRIPTOR (see table 460) contains information identifying the logical unit, physical device, or access path used by the 
command and returned parameter data. 


Table 460 Identification Descriptor 





Bit 7 6 5 4 3 2 1 0 
Byte 
0 PROTOCOL IDENTIFIER CODE SET 
PIV Reserved ASSOCIATION IDENTIFIER TYPE 
Reserved 
IDENTIFIER LENGTH (n - 3) 
































N 





w 





- 





IDENTIFIER 

















PROTOCOL IDENTIFIER field 


The PROTOCOL IDENTIFIER field may indicate the SCSI transport protocol to which identification descriptor applies. If the ASSOCIATION field 
contains a value other than 1h or 2h or the PIV bit is set to zero, then the PROTOCOL IDENTIFIER field should be ignored. If the ASSOCIATION 
field contains a value of 1h or 2h and the PIV bit is set to one, then the PROTOCOL IDENTIFIER field shall contain one of the values shown in 
table 461 to indicate the SCSI transport protocol to which identification descriptor applies. 


CODE SET field 
The CODE SET field specifies the code set used for the identifier field, as described in Table . This field is intended to be an aid to software that 
displays the identifier field. 





Value Description 





Oh _ | Reserved 
1h | The IDENTIFIER field shall contain binary values 





2h The IDENTIFIER field shall contain ASCII graphic codes (i.e., code values 20h through 7Eh) 





3h- Fh | Reserved 
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PIV (Protocol Identifier Valid) bit 


0 A protocol identifier valid (PIV) bit of zero indicates the PROTOCOL IDENTIFIER field should be ignored. If the ASSOCIATION field contains 
a value of 1h or 2h then a PIV bit set to one indicates the PROTOCOL IDENTIFIER field contains a valid protocol identifier selected from 
the values shown in table 461. If the ASSOCIATION field contains a value other than 1h or 2h then the PIV bit should be ignored. 


Table 461 PROTOCOL IDENTIFIER values 





























Protocol Identifier Description Protocol Standard 

Oh Fibre Channel FCP-4 
th Obsolete 
2h SSA SSA-S3P 
3h IEEE 1394 SBP-2 
4h Remote Direct Memory Access (RDMA) SRP 
5h Internet SCSI iSCSI 
6h SAS Serial SCSI Protocol SAS 

7h- Fh Reserved 

















ASSOCIATION field 


The ASSOCIATION field indicates the entity that the Identification descriptor describes. If a physical or logical device returns an Identification 
descriptor with the ASSOCIATION field set to Oh, it shall return the same descriptor when it is accessed through any other path. 


The ASSOCIATION field specifies the entity with which the Identifier field is associated, as described in Table 462. 


Table 462 ASSOCIATION field 


Value Description 





Oh The IDENTIFIER field is associated with the addressed physical or logical device 





th The IDENTIFIER field is associated with the port that received the request 





2h The IDENTIFIER field is associated with the SCSI target device that contains the addressed logical unit. 











3h Reserved 








SCSI Commands Reference Manual, Rev. J 492 


www.seagate.com Parameters for direct access devices 


IDENTIFIER TYPE field 
The IDENTIFIER TYPE field specifies the format and assignment authority for the identifier, as described in tables 463 and 464. 


Table 463 IDENTIFIER Type field 





Value Description 





Oh No assignment authority was used and consequently there is no guarantee that the identifier is globally unique (i.e., 
the identifier is vendor specific). 





The first 8 bytes of the IDENTIFIER field are a Vendor ID. The organization associated with the Vendor ID is responsible 
th for ensuring that the remainder of the identifier field is unique. One recommended method of constructing the 
remainder of the identifier field is to concatenate the product identification field from the standard INQUIRY data field 
and the product serial number field from the unit serial number page. 





The IDENTIFIER field contains a Canonical form IEEE Extended Unique Identifier, 64-bit (EUI-64). In this case, the identi- 
2h fier length field shall be set to 8. Note that the IEEE guide-lines for EUI-64 specify a method for unambiguously encap- 
sulating an IEEE 48-bit identifier within an EUI-64. 





The IDENTIFIER field contains an FC-PH, FC-PH3 or FC-FS Name_lIdentifier. Any FC-PH, FC-PH3 or FC-FS identifier may 
3h : : : : 
be used, including one of the four based on a Canonical form IEEE company_id. 





If the ASSOCIATION field contains 1h, the Identifier value contains a four-byte binary number identifying the port rela- 
4h tive to other ports in the device using the values shown Table 462. The CODE SET field shall be set to 1h and the IDEN- 
TIFIER LENGTH field shall be set to 4h. If the ASSOCIATION field does not contain 1h, use of this identifier type is 
reserved. 





If the Association value is 1h, the Identifier value contains a four-byte binary number identifying the port relative to 
5h other ports in the device using the values shown Table 462. The CODE SET field shall be set to 1h and the IDENTIFIER 
LENGTH field shall be set to 4h. If the ASSOCIATION field does not contain 1h, use of this identifier type is reserved. 





If the ASSOCIATION value is Oh, the IDENTIFIER value contains a four-byte binary number identifying the port relative 
6h to other ports in the device using the values shown Table 462. The CODE SET field shall be set to 1h and the IDENTI- 
FIER LENGTH field shall be set to 4h. If the ASSOCIATION field does not contain Oh, use of this identifier type is 
reserved. 





The MDS logical unit identifier shall not be used if a logical unit provides unique identification using identifier types 
7h 2h or 3h. A bridge device may return a MDS logical unit identifier type for that logical unit that does not support the 
Device Identification VPD page. 


8h-Fh_ | Reserved. 
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IDENTIFIER LENGTH field 


The IDENTIFIER LENGTH field specifies the length in bytes of the IDENTIFIER field. If the ALLOCATION LENGTH field of the command descriptor 
block is too small to transfer all of the identifier, the identifier length shall not be adjusted to reflect the truncation. 


IDENTIFIER field 


The IDENTIFIER field contains the identifier as described by the Association, Identifier Type, CODE SET, and IDENTIFIER LENGTH fields. The 
example described in this clause and shown in Table 464 is not a normative part of this manual. This example of a complete device identifica- 
tion VPD page assumes that the product is a direct-access device with an T10 Vendor ID of “XYZ_Corp,’a product identification of “Super Turbo 
Disk,’ and a product serial number of “2034589345.” Furthermore, it is assumed that the manufacturer has been assigned a 24-bit IEEE compa- 
ny_id of 01ABCDh by the IEEE Registration Authority Committee and that the manufacture has assigned a 24-bit extension_identifier of 
234567h to this logical unit. The combined 48-bit identifier is reported in the 64-bit format as defined by the IEEE 64-bit Global Identifier 
(EUI-64) standard. The data returned in the device identification VPD page for this logical unit is shown in Table 464. 


Table 464 Device Identification page example 








Bytes Hexadecimal values ASCII values 
00-15 | 00 83 O00 32 02 O01 OO 22 58 59 5A 5F 43 6F 72 = 70 ...2..XYZ_Corp [5] 
16-31 53 75 70 65 72 20 54 75 72 62 6F 20 44 69 73 6B Super Turbo Disk 
32-47 | 32 30 33 34 35 38 39 33 34 35 O01 O02 OO O08 O01 AB 2034589345... 
48-53 | CD FF FF 23 45 67 








Notes. 
a) Non-printing ASCII characters are shown as“. 
b) Byte 00 is the beginning of the VPD page (see table 437). 
c) Byte 04 is the beginning of the Identification descriptor for the Vendor ID based identifier (Identifier type 1 see Table 463). 
d) Byte 42 is the beginning of the Identification Descriptor for the EUI-64 identifier (Identifier type 2, see Table 463). 
e) 


For Seagate devices, this will say “Seagate.” 
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5.4.12 Jumper Settings page (C2h) 


The Jumper Settings VPD page is obsolete and not supported on newer products. 


Table 465 Jumper Settings page (C2h) 

































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 

1 PAGE CODE (C2h) 

2 00h 

3 PAGE LENGTH (02h) 

4 DS MS WP PE DRIVE ID 

5 Reserved TE 








PERIPHERAL QUALIFIER and PERIPHERAL DEVICE TYPE fields 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field 
The PAGE CODE field shall be set to the value defined in table. 


PAGE LENGTH field 


The PAGE LENGTH field specifies the length of the following VPD page data. The relationship between the PAGE LENGTH field and the CDB 
ALLOCATION LENGTH field is defined in 2.2.6. 


DS (Delayed Motor Start) bit 
The Delayed Motor Start (DS) bit when set to 1 indicates that this jumper is on. 


MS (Motor Start) bit 
The Motor Start (MS) bit when set to 1 indicates that the jumper is on. 


WP (Write Protect) bit 


The Write Protect (WP) bit when set to 1 indicates that the write protect jumper is on. 


PE (Parity Enable) and PD (Parity Disable) bits 


NOTE _ These bits are obsolete and are not supported. 
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Drive ID field 


Parameters for direct access devices 


The Drive ID is shown below in Table 466. Bit 3 is the most significant bit and bit 0 is the least significant bit. 





















































Table 466 Drive ID bit 
Bit 3 Bit 2 Bit 1 Bit 0 Drive ID 

0 0 0 0 0 
0 0 0 1 1 

0 0 1 0 2 

0 0 1 1 3 

0 1 0 0 4 
0 1 0 1 5 

0 1 1 0 6 
0 1 1 1 7 
1 0 0 0 8 
1 0 0 1 9 
1 0 1 0 10 
1 0 1 1 11 
1 1 0 0 12 
1 1 0 1 13 
1 1 1 0 14 
1 1 1 1 15 























TE (Terminator Enable) bit 


NOTE 
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5.4.13 Logical Block Provisioning VPD page (82h) 


The Logical Block Provisioning VPD page (see table 467) provides the application client with logical block provisioning related 
operating parameters of the logical unit. 


Table 467 _Logical Block Provisioning VPD page 
















































































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 

1 PAGE CODE (B2h) 

2 (MSB) 

PAGE LENGTH (n - 3) 

3 (LSB) 
4 THRESHOLD EXPONENT 

5 LBPU LBPWS LBPWS10 LBPRZ ANC_SUP DP 
6 MINIMUM PERCENTAGE PROVISIONING TYPE 

7 THRESHOLD PERCENTAGE 

8 
aes PROVISIONING GROUP DESCRIPTOR (if any) 
63 











PERIPHERAL QUALIFIER and PERIPHERAL DEVICE TYPE fields 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in SPC-5. 


PAGE CODE field 
The PAGE CODE field is defined in SPC-5 and shall be set to the value shown in table 467 for the Logical Block Provisioning VPD page. 


PAGE LENGTH field 

The PAGE LENGTH field is defined in SPC-5. If the DP bit is set to zero, then the PAGE LENGTH field shall be set to 0004h. If the DP bit is set to 
one, then the PAGE LENGTH field shall be set to the value defined in table 467. 

THRESHOLD EXPONENT field 


The THRESHOLD EXPONENT field set to a non-zero value indicates the threshold set size in LBAs as a power of 2 (i.e., the threshold set size is 


equal to 2(threshold exponent)) 4 THRESHOLD EXPONENT field set to zero indicates that the logical unit does not support logical block provision- 
ing thresholds. 


If logical block provisioning thresholds are supported, then the threshold exponent shall be a non-zero value selected such that: 
(capacity a 2 (threshold exponent), < 2(32) 
where: 


capacity is 1 + the LBA of the last logical block as returned in the READ CAPACITY (16) parameter data (see 3.23.2) 
(i.e, the number of logical blocks on the direct access block device); 


and 
2°32) is the constant value 1_0000_0000h (i.e., 4 294 967 296). 
LBPU bit 


1 A logical block provisioning unmap (LBPU) bit set to one indicates that the device server supports the UNMAP command (see 3.54). 
0 = An LBPU bit set to zero indicates that the device server does not support the UNMAP command. 
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LBPWS bit 


1 A logical block provisioning write same (LBPWS) bit set to one indicates that the device server supports the use of the WRITE SAME (16) 
command (see 3.74) to unmap LBAs. 


0 = AnLBPWS bit set to zero indicates that the device server does not support the use of the WRITE SAME (16) command to unmap LBAs. 


LBPWS10 bit 


1 A logical block provisioning write same 10 (LBPWS10) bit set to one indicates that the device server supports the use of the WRITE SAME 
(10) command (see 3.73) to unmap LBAs. 


0 AnLBPWS10 bit set to zero indicates that the device server does not support the use of the WRITE SAME (10) command to unmap LBAs. 


LBPRZ field 
The logical block provisioning read zeros (LBPRZ) field is described in table 468. 


Table 468 _LBPRZ field 

















Code Description 

000b The logical block data represented by unmapped LBAs is vendor specific 

xx1b The logical block data represented by unmapped LBAs is set to zeros 

010b The logical block data represented by unmapped LBAs is set to the provisioning initialization pattern 
All others Reserved 











ANC_SUP bit 
1 An anchor supported (ANC_SUP) bit set to one indicates that the device server supports anchored LBAs (see SBC-4). 
0 An ANC_SUP bit set to zero indicates that the device server does not support anchored LBAs. 


DP bit 
1 A descriptor present (DP) bit set to one indicates a PROVISIONING GROUP DESCRIPTOR field is present. 


0 ADP bit set to zero indicates a PROVISIONING GROUP DESCRIPTOR field is not present. 


MINIMUM PERCENTAGE field 


A MINIMUM PERCENTAGE field set to zero indicates that the logical unit does report a minimum percentage of resources required by the 
device. A MINIMUM PERCENTAGE field set to a non-zero indicates the minimum percentage of resources required by the device server as 
described in table 469. This value indicates the point where a device server may begin device initiated advanced background operations. 


Table 469 MINIMUM PERCENTAGE field 











Code Description 
0 The logical unit does not report a minimum percentage of resources required 
1 to 30 


9 0, 1 
(ie, O1h to 1Eh 1% to 30% of the total allocation resources 





All others Reserved 
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PROVISIONING TYPE field 
The PROVISIONING TYPE field is defined in table 470. 


Table 470 _— Provisioning Type field 























Code Description 
000b The device server does not report a provisioning type. 
001b The logical unit is resource provisioned (see SBC-4). 
010b The logical unit is thin provisioned (see SBC-4). 

All others Reserved 





THRESHOLD PERCENTAGE field 


A THRESHOLD PERCENTAGE field set to zero indicates that the logical unit does not support logical block provisioning percentages. If logical 
block provisioning percentages are supported, then the threshold percentage shall be set to a non-zero value selected from the values in table 
471.The units for the threshold percentage is tenths of a percent. This percentage represents the range over which logical block provisioning 
threshold percentages operates as described in SBC-4. 


Table 471 MINIMUM PERCENTAGE field 








Code Description 
0 The logical unit does not support logical block provisioning percentages 
1to 255 . 
(ie. O1h to FFh 0.1% to 25.5% of the total allocation resources 











PROVISIONING GROUP DESCRIPTOR field 


The PROVISIONING GROUP DESCRIPTOR field, if any, contains a designation descriptor (see SPC-5) for the LBA mapping resources used by this 
logical unit. 


If a PROVISIONING GROUP DESCRIPTOR field is present: 
a) the ASSOCIATION field shall be set to 00b (i.e. logical unit); and 
b) the DESIGNATOR TYPE field shall be set to: 

A) — th(i.e.,T10 vendor ID based); or 

B) 3h (i.e., NAA). 
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5.4.14 Mode Page Policy VPD page (87h) 


The Mode Page Policy VPD page (see table 472) indicates which mode page policy (see table 3.9) is in effect for each mode page supported by 
the logical unit. 


Table 472 Mode Page Policy VPD page 












































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 
1 PAGE CODE (87h) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 
Mode page policy descriptor list 
4 
ae Mode page policy descriptor [first] (see table 473) 
7 
n-3 
Mode page policy descriptor [last] (see table 473) 
n 


PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field 
The PAGE CODE field is defined in SPC-5 and shall be set to the value defined in table 472. 


PAGE LENGTH field 


The PAGE LENGTH field indicates the length of the mode page policy descriptor list. The relationship between the PAGE LENGTH field and the 
CDB ALLOCATION LENGTH field is defined in 2.2.6. 


Each mode page policy descriptor (see table 473) contains information describing the mode page policy for one or more mode pages or 
subpages (see 5.3.5). The information in the mode page policy descriptors in this VPD page shall describe the mode page policy for every 
mode page and subpage supported by the logical unit. 


Table 473. Mode page policy descriptor 















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 Reserved POLICY PAGE CODE 

1 POLICY SUBPAGE CODE 

2 MLUS Reserved MODE PAGE POLICY 

3 Reserved 
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POLICY PAGE CODE field and POLICY SUBPAGE CODE field 
The POLICY PAGE CODE field and POLICY SUBPAGE CODE field indicate the mode page and subpage to which the descriptor applies. 


If the first mode page policy descriptor in the list contains a POLICY PAGE CODE field set to 3Fh and a POLICY SUBPAGE CODE field set to FFh, 
then the descriptor applies to all mode pages and subpages not described by other mode page policy descriptors. The POLICY PAGE CODE 
field shall be set to 3Fh and the POLICY SUBPAGE CODE field shall be set to FFh only in the first mode page policy descriptor in the list. 


If the POLICY PAGE CODE field contains a value other than 3Fh and a POLICY SUBPAGE CODE field contains a value other than FFh, then the 
POLICY PAGE CODE field and the POLICY SUBPAGE CODE field indicate a single mode page and subpage to which the descriptor applies. 


If the POLICY PAGE CODE field contains a value other than 3Fh, then POLICY SUBPAGE CODE field shall contain a value other than FFh. If the 
POLICY SUBPAGE CODE field contains a value other than FFh, then POLICY PAGE CODE field shall contain a value other than 3Fh. 

MLUS bit 

If the SCSI target device has more than one logical unit: 


1 A multiple logical units share (MLUS) bit set to one indicates the mode page and subpage identified by the POLICY PAGE CODE field and 
POLICY SUBPAGE CODE field is shared by more than one logical unit. 


0 AMLUS bit set to zero indicates the logical unit maintains its own copy. 
The MLUS bit is set to one in the mode page policy descriptors or descriptor that indicates the mode page policy for the: 
a) Disconnect-Reconnect mode page (see 5.3.14) for FC, and (see 5.3.15) for SAS and; 
b) Protocol Specific Port mode page (see 5.3.26). 
MODE PAGE POLICY field 


The MODE PAGE POLICY field (see table 474) indicates the mode page policy for the mode page and subpage identified by the POLICY PAGE 
CODE field and POLICY SUBPAGE CODE field. 


Table 474 MODE PAGE POLICY field 

















Code Description 
00b Shared 
01b Per target port 
10b Obsolete 
11b Per |_T nexus 
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5.4.15 Power Conditions Vital Product Data page (8Ah) 


The Power Condition VPD page (see table 475) indicates which power conditions (see SPC-5) are supported by the logical unit and provides 
information about how those power conditions operate. 


Table 475 Power Condition VPD page 
















































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 
PAGE CODE (8Ah) 
2 (MSB) 
PAGE LENGTH (000Eh) 
3 (LSB) 
4 Reserved STANDBY_Y | STANDBY_Z 
5 Reserved IDLE_C IDLE_B IDLE_A 
6 (MSB) 
STOPPED CONDITION RECOVERY TIME 
7 (LSB) 
8 (MSB) 
STANDBY_Z CONDITION RECOVERY TIME 
9 (LSB) 
10 (MSB) 
STANDBY_Y CONDITION RECOVERY TIME 
11 (LSB) 
12 (MSB) 
IDLE_A CONDITION RECOVERY TIME 
13 (LSB) 
14 (MSB) 
IDLE_B CONDITION RECOVERY TIME | 
15 (LSB) 
16 (MSB) 
a Ee IDLE_C CONDITION RECOVERY TIME —_—____ 
17 (LSB) 











PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field and PAGE LENGTH field 
These fields are defined in SPC-5, and shall be set to the value shown in table 475 for the Power Condition VPD page. 


If set to one, a power condition support bit (i-e., the STANDBY_Y bit, the STANDBY_Z bit, the IDLE_C bit, the IDLE_B bit, and the IDLE_A bit) indi- 
cates that: 
a) the associated power condition may be entered with the START STOP UNIT command (see SBC-4) if that command is implemented; and 


b) the associated power condition may be entered with a power condition timer if the associated timer is supported and 
enabled (see 5.3.20). 


STANDBY_Y power conditions support bit 
1 This bit set to one indicates that the logical unit supports the standby_y power condition as described in this subclause. 


0 This bit set to zero indicates that the logical unit does not support the standby_y power condition. 


STANDBY_Z power conditions support bit 
1 This bit set to one indicates that the logical unit supports the standby_z power condition as described in this subclause. 


0 This bit set to zero indicates that the logical unit does not support the standby_z power condition. 


IDLE_C power conditions support bit 
1 This bit set to one indicates that the logical unit supports the idle_c power condition as described in this subclause. 


0 AIDLE_C bit set to zero indicates that the logical unit does not support the idle_c power condition. 
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IDLE_B power conditions support bit 
1 This bit set to one indicates that the logical unit supports the idle_b power condition as described in this subclause. 


0  AIDLE_B bit set to zero indicates that the logical unit does not support the idle_b power condition. 


IDLE_A power conditions support bit 
1 This bit set to one indicates that the logical unit supports the idle_a power condition as described in this subclause. 


0 AIDLE_A bit set to zero indicates that the logical unit does not support the idle_a power condition. 


STOPPED CONDITION RECOVERY TIME field 


This field indicates the time, in one millisecond increments, that the logical unit takes to transition from the stopped power condition to the 
active power condition. This field is only applicable to SCSI target devices that implement the START STOP UNIT command (see SBC-4). This 
time does not include the processing time for the command that caused this transition to occur or any SCSI transport protocol specific waiting 
time (e.g., the NOTIFY (ENABLE SPINUP) requirement described in SPL-4). A value of zero indicates that the recovery time is not specified. A 
value of FFFFh indicates that the recovery time is more than 65.534 seconds. 


STANDBY_Z CONDITION RECOVERY TIME field 


This field indicates the time, in one millisecond increments, that the logical unit takes to transition from the standby_z power condition to the 
active power condition. This time does not include the processing time for the command that caused this transition to occur or any SCSI trans- 
port protocol specific waiting time (e.g., the NOTIFY (ENABLE SPINUP) requirement described in SPL). A value of zero indicates that the recovery 
time is not specified. A value of FFFFh indicates that the recovery time is more than 65.534 seconds. 


STANDBY_Y CONDITION RECOVERY TIME field 


This field indicates the time, in one millisecond increments, that the logical unit takes to transition from the standby_y power condition to the 
active power condition. This time does not include the processing time for the command that caused this transition to occur or any SCSI trans- 
port protocol specific waiting time (e.g., the NOTIFY (ENABLE SPINUP) requirement described in SPL). A value of zero indicates that the recovery 
time is not specified. A value of FFFFh indicates that the recovery time is more than 65.534 seconds. 


IDLE_A CONDITION RECOVERY TIME field 


This field indicates the time, in one millisecond increments, that the logical unit takes to transition from the idle_a power condition to the 
active power condition. This time does not include the processing time for the command that caused this transition to occur. A value of zero 
indicates that the recovery time is not specified. A value of FFFFh indicates that the recovery time is more than 65.534 seconds. 


IDLE_B CONDITION RECOVERY TIME field 


This field indicates the time, in one millisecond increments, that the logical unit takes to transition from the idle_b power condition to the 
active power condition. This time does not include the processing time for the command that caused this transition to occur. A value of zero 
indicates that the recovery time is not specified. A value of FFFFh indicates that the recovery time is more than 65.534 seconds. 


IDLE_C CONDITION RECOVERY TIME field 


This field indicates the time, in one millisecond increments, that the logical unit takes to transition from the idle_c power condition to the 
active power condition. This time does not include the processing time for the command that caused this transition to occur. A value of zero 
indicates that the recovery time is not specified. A value of FFFFh indicates that the recovery time is more than 65.534 seconds. 
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5.4.16 Power Consumption Vital Product Data page (8Dh) 


The Power Consumption VPD page (see table 476) provides an application client with a list of the available settings to limit the maximum 
power consumption of the logical unit while in the active power condition (see SPC-5). 


Table 476 Power Consumption VPD page 



































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 
1 PAGE CODE (8Dh) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 
Power consumption descriptor list 
4 
aa Power consumption descriptor [first] 
7 
n-3 
Power consumption descriptor [last] 
n 











PERIPHERAL QUALIFIER and PERIPHERAL DEVICE TYPE fields 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 
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PAGE CODE and PAGE LENGTH fields 

The PAGE CODE field and PAGE LENGTH field are defined in SPC-5, and shall be set to the value shown in table 476 for the Power Consumption 
VPD page. 

Each power consumption descriptor (see table 477) describes one maximum power consumption level that the application client may estab- 
lish for use by the active power condition (see SPC-5) using the Power Consumption mode page (see 5.3.20) as described in SPC-5. 


Table 477 Power consumption descriptor format 









































Bit 7 6 5 4 3 2 1 0 
Byte 
0 POWER CONSUMPTION IDENTIFIER 
1 Reserved POWER CONSUMPTION UNITS 
2 MSB 
( POWER CONSUMPTION VALUE 
3 (LSB) 








POWER CONSUMPTION IDENTIFIER field 


The POWER CONSUMPTION IDENTIFIER field provides a reference handle to specify which descriptor is selected by the Power Consumption 
mode page as described in SPC-5. 


POWER CONSUMPTION UNITS field 
The POWER CONSUMPTION UNITS field (see table 478) indicates the units used for the POWER CONSUMPTION VALUE field. 


Table 478 POWER CONSUMPTION UNITS field 








Code Description 
000b Gigawatts 
001b Megawatts 
010b Kilowatts 
011b Watts 

100b Milliwatts 
101b Microwatts 
all others Reserved 














POWER CONSUMPTION VALUE field 


The POWER CONSUMPTION VALUE field indicates the maximum power consumption associated with the identifier in the POWER CONSUMP- 
TION IDENTIFIER field using the units specified by the POWER CONSUMPTION UNITS field. 
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SCSI Ports VPD page (88h) 


The SCSI Ports VPD page (see table 479) contains designation descriptors for all the SCSI ports in a SCSI target device. 


The SCSI Ports VPD page only reports information on SCSI ports known to the device server processing the INQUIRY command. The REPORT 
LUNS well-known logical unit (see 3.33) may be used to return information on all SCSI ports in the SCSI device (i.e., all target ports and all 
initiator ports). 


If the device server detects that a SCSI port is added or removed from the SCSI device and the SCSI port designation descriptor list changes, 
then the device server shall establish a unit attention condition (see SAM-5) for the initiator port associated with every |_T nexus, with the 
additional sense code set to INQUIRY DATA HAS CHANGED. 






























































Table 479 SCSI Ports VPD page 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 
1 PAGE CODE (88h) 
2 (MSB) 
PAGE LENGTH (n-3) 
3 (LSB) 
Designation descriptor list 
4 
SCSI port designation descriptor [first] (see table 480) 
SCSI port designation descriptor [last] (see table 480) 
n 














PERIPHERAL QUALIFIER and PERIPHERAL DEVICE TYPE fields 
The PERIPHERAL QUALIFIER field and PAGE LENGTH field are defined in standard INQUIRY data (see 3.6.2). 
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PAGE CODE and PAGE LENGTH fields 
The PAGE CODE field and PAGE LENGTH field are defined in SPC-5, and shall be set to the value shown in table 479 for the SCSI Ports VPD page. 


Each SCSI port designation descriptor (see table 480) identifies a SCSI port. The SCSI port designation descriptors may be returned in any order. 




































































Table 480 SCSI port designation descriptor 
Bit 7 6 5 4 3 2 1 0 
Byte 
0 
Reserved 
1 
2 (MSB) 
RELATIVE PORT IDENTIFIER (see table 481) 
3 (LSB) 
4 
Reserved 
5 
6 (MSB) 
INITIATOR PORT TRANSPORTID LENGTH (k-7) 
7 (LSB) 
8 
INITIATOR PORT TRANSPORTID (if any) 
k 
k+1 
Reserved 
k+2 
k+3 (MSB) 
TARGET PORT DESCRIPTORS LENGTH (n-(k+4) 
k+4 (LSB) 
Target port descriptor list 
k+5 
Target port descriptor [first] (see table 479) 
Target port descriptor [last] (see table 479) 
n 
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RELATIVE PORT IDENTIFIER field 


The RELATIVE PORT IDENTIFIER field (see table 481) contains the relative port identifier of the SCSI port to which the SCSI port designation 
descriptor applies. 


Table 481 _—_— Relative Port Identifier field 














Code Description 

Oh Reserved 

th Relative port 1, historically known as port A 
2h Relative port 1, historically known as port B 
3h to FFFFh Relative port 3 through 65 535 





INITIATOR PORT TRANSPORTID LENGTH field 
The INITIATOR PORT TRANSPORTID LENGTH field indicates the length of the INITIATOR PORT TRANSPORTID field. 
zero value indicates no INITIATOR PORT TRANSPORTID field is present (i.e., the SCSI port is not an initiator port). 


non-zero value indicates a TransportID identifying the initiator port as defined in SPC-5. 


TARGET PORT DESCRIPTORS LENGTH field 


The TARGET PORT DESCRIPTORS LENGTH field indicates the length of the target port descriptors, if any. A TARGET PORT DESCRIPTORS LENGTH 
field set to zero indicates no target port descriptors are present (i.e., the SCSI port is not a target port). 


Each target port descriptor (see table 482) contains an identifier for the target port. The target port descriptors may be returned in any order. 


Table 482 Target port Descriptor 





Bit 7 6 5 4 3 2 1 0 
Byte 
0 PROTOCOL IDENTIFIER CODE SET 
PIV (1b) Reserved ASSOCIATION (01b) DESIGNATOR TYPE 
Reserved 
DESIGNATOR LENGTH (n - 3) 

















WIN; = 





- 





DESIGNATOR 














PROTOCOL IDENTIFIER field 

The PROTOCOL IDENTIFIER field indicates the SCSI transport protocol to which the designation descriptor applies as described in 
table 482. 

CODE SET field, PIV field, ASSOCIATION field, DESIGNATOR TYPE field, DESIGNATOR LENGTH field, and DESIGNATOR field 


The CODE SET field, PIV field, ASSOCIATION field, DESIGNATOR TYPE field, DESIGNATOR LENGTH field, and DESIGNATOR field are 
as defined in the Device Identification VPD page designation descriptor (see SPC-5), with the following additional requirements: 


a) the PIV bit shall be set to one (i.e., the PROTOCOL IDENTIFIER field always contains a SCSI transport protocol identifier); and 
b) the ASSOCIATION field shall be set to 01b (i.e., the descriptor always identifies a target port). 
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5.4.18 Supported Vital Product Data pages (00h) 


This clause contains a list of the vital product data page codes supported by the target or logical unit (see table 483). If a target supports any 
vital product data pages, it also shall support this vital product data page. 


Table 483 Supported Vital Product Data pages 















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 

1 PAGE CODE (00h) 

2 Reserved 

3 PAGE LENGTH (n-3) 

4 

SUPPORTED PAGE LIST 
n 














PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field 
The PAGE CODE field is defined in SPC-5 and shall be set to the value defined in table 483. 


PAGE LENGTH field 


The PAGE LENGTH field indicates the length of the mode page policy descriptor list. The relationship between the PAGE LENGTH field and the 
CDB ALLOCATION LENGTH field is defined in 2.2.6. 


SUPPORTED PAGE LIST field 


The SUPPORTED PAGE LIST field shall contain a list of all vital product data page codes (see 5.4.1) implemented for the target or logical unit in 
ascending order beginning with page code 00h. 
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5.4.19 Unit Serial Number page (80h) 


The Unit Serial Number page provides a product serial number for the target or logical unit. See Table 484 following. 


Table 484 Unit Serial Number page (80h) 















































Bit 7 6 5 4 3 2 1 0 
Byte 

0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 

1 PAGE CODE (80h) 

2 Reserved 

3 PAGE LENGTH 

4 

Product Serial Number 
n 














PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field 
The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE field 
The PAGE CODE field shall be set to the value defined in table 484. 


PAGE LENGTH field 


The PAGE LENGTH field specifies the length in bytes of the product serial number page. Older products that only support the Product Serial 
Number parameter will have a page length of 08h, while newer products that support both parameters will have a page length of 14h. If the 
ALLOCATION LENGTH is too small to transfer all of the page, the page length shall not be adjusted to reflect the truncation. 


Product Serial Number field 


The Product Serial Number field contains ASCII data that is vendor-assigned serial number. The least significant ASCII character of the serial 
number shall appear as the last byte in the Data-In Buffer. If the product serial number is not available, the target shall return ASCII spaces (20h) 
in this field. 
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5.4.20 Zoned Block Device Characteristics VPD page (B6h) 


The Zoned Block Device Characteristics VPD page (see table 485) provides a list of parameters that are specific to zoned block devices. 


Table 485 Zoned Block Device Characteristics VPD page 































































































Bit 7 6 5 4 3 2 1 0 
Byte 
0 PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 
1 PAGE CODE (B6h) 
2 
3 PAGE LENGTH (003Ch) 
4 Reserved URSWRZ 
5 
Reserved 

7 

(MSB) 

OPTIMAL NUMBER OF OPEN SEQUENTIAL WRITE PREFERRED ZONES 
11 (LSB) 
12 (MSB) 
OPTIMAL NUMBER OF NON-SEQUENTIALLY WRITTEN 
SEQUENTIAL WRITE PREFERRED ZONES ee | 
15 (LSB) 
16 (MSB) 
MAXIMUM NUMBER OF OPEN SEQUENTIAL WRITE REQUIRED ZONES 
19 (LSB) 
20 
Reserved 

63 
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PERIPHERAL QUALIFIER and PERIPHERAL DEVICE TYPE fields 
The PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field are defined in standard INQUIRY data (see 3.6.2). 


PAGE CODE and PAGE LENGTH fields 


The PAGE CODE field and PAGE LENGTH field are defined in SPC-5 and shall be set to the values shown in table 485 for the Zoned Block Device 
Characteristics VPD page. 


URSWRZ bit 


0 = Anunrestricted read in sequential write required zone (URSWRZ) bit set to zero indicates that the device server does not support read- 
ing unwritten logical blocks or reads across zone boundaries in sequential write required zones. 


1 A URSWRZ bit set to one indicates that the device server supports reading unwritten logical blocks and reads across zone boundaries in 
sequential write required zones. 


OPTIMAL NUMBER OF OPEN SEQUENTIAL WRITE PREFERRED ZONES field 


The OPTIMAL NUMBER OF OPEN SEQUENTIAL WRITE PREFERRED ZONES field indicates the recommended upper limit for the number of 
sequential write preferred zones that are open zones. A value of FFFF_FFFFh indicates that the optimal number of sequential write preferred 
zones that are open zones is not reported. 


OPTIMAL NUMBER OF NON-SEQUENTIALLY WRITTEN SEQUENTIAL WRITE PREFERRED ZONES field 


The OPTIMAL NUMBER OF NON-SEQUENTIALLY WRITTEN SEQUENTIAL WRITE PREFERRED ZONES field indicates the recommended upper limit 
for the number of sequential write preferred zones in which at least one non-sequential write operation has occurred (see ZBC). A value of 
FFFF_FFFFh indicates that the optimal number of non-sequentially written sequential write preferred zones is not reported. 


MAXIMUM NUMBER OF OPEN SEQUENTIAL WRITE REQUIRED ZONES field 


The MAXIMUM NUMBER OF OPEN SEQUENTIAL WRITE REQUIRED ZONES field indicates the maximum number of sequential write required 
zones that are allowed to be open zones (see ZBC). A value of FFFF_FFFFh indicates that there is no limit for the number of sequential write 
required zones having a Zone Condition of IMPLICIT OPEN and EXPLICIT OPEN. 
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Abbreviations 33 
ABPF. See Abort Prefetch 
ADDITIONAL CDB LENGTH 40 
ADDITIONAL CDB LENGTH field 40 
ADDITIONAL LENGTH 94, 116 
ADDITIONAL LENGTH field 97 
Diagnostic Data Bytes 171 
Standard Inquiry Data 94 
Additional Length 
Diagnostic Data Bytes 171 
Additional sense 25 
additional sense 
qualifier code 60 
Additional Sense code 25 
additional sense code 60 
Address Field Logical Block Address Format 295 
Address Field Physical Sector Address Format 296 
ALLOCATION LENGTH 
CDB 10-byte 38 
CDB 12-byte 39 
CDB 6-byte 38 
CDB for long LBA 16-byte 39 
CDB for long LBA 32-byte 41 
Definition 43 
Receive Diagnostic Results command 171 
Allocation Length 
Inquiry command 93 
Log Sense command 106 
Mode Sense command 111 
Persistent Reserve In command 115 
Read Buffer command 144 
Read Capacity command 86, 89, 154, 157 
Read Defect Datacommand 160 
Report Device Identifier command 176 
Report LUNS command 179, 189 
Request Sense command 195 
Allocation length 43 
ALLOCATION LENGTH field 
Receive Diagnostic Results command 171 
Allow Login Without Loop Initialization 
Fibre Channel Interface Control page 435, 437 
ALWLI. See Allow Login Without Loop Initialization 
Application Client log page 310 
ARRE bit 428 
ASCII Information 469 
ASCII Information VPD page (O1h-7Fh) 469 
AWRE bit 428 


Background Control mode 
Page description 388 
Background medium scan features 313 
Background Scan log page 312 
BLOCK DESCRIPTOR 378 
Block Device Characteristics 470 
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Block Device Characteristics Extension 473 
Block Device Characteristics VDP page (B1h) 470 
BLOCK LENGTH IN BYTES 156 

BLOCK LENGTH IN BYTES field 156 
Block Limits 475 
Block Limits Extension 480 
BUFFER CAPACITY 

BUFFER CAPACITY field 145 

Read Buffer Header 145 
BUFFER ID 

Read Buffer Command 144 

Write Buffer Command 264 
BUFFER OFFSET 

Read Buffer Command 144 


C 


Cache Statistics 319 
Cache statistics page 319 
CHANGE DEFINITION command 69 
Change Definition command 69 
check condition status 45 
Command 

alphabetical listing 65 

for all devices 65 

for direct access devices 65 
Command Descriptor Block (CDB) 37 
Command type 

Alldevices 65 

Direct access devices 65 
Compile Date Code 

ETF Log Date Code page 481 
Control mode page (OAh) 397 
Conventions 36 


D 


Date Code 481 
Date Code page 481 
DDIS. See Disable Discovery 
Definitions 25 
Device Behavior 482 
Device Identification 490 
Device type field 357, 358, 374, 375 
Diagnostic Data Bytes 
Receive Diagnostic Results command 171 
Diagnostic data list 171 
Diagnostic operation 171 
Diagnostic page format 292 
Diagnostic Parameters 
Background Scan log page 312 
Cache Statistics page 319 
Log page codes 302 
PAGE CODE field identifies 292 
Supported Diagnostic Pages 294 
Supported Log Pages log page 369 
Temperature log page 371 
Diagnostic parameters 292 
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Direct access block commands 65 
Disable Discovery 

Fibre Channel Interface Control page 435, 436, 437 
Disable Loop Master 

Fibre Channel Interface Control page 435, 437 
Disable Page Out bit 139 
Disable Prefetch Transfer Length 

Caching Parameters page 392 
Disable Soft Address 

Fibre Channel Interface Control page 435, 437 
Disable Target Fabric Discovery 

Fibre Channel Interface Control page 435, 436 
Disable Target Initiated Port Enable 

Fibre Channel Interface Control page 435, 437 
Disable Target Oriented Loop Initialization 

Fibre Channel Interface Control page 435, 437 
Disabled Physical Element 


Translate Address page 299, 300 
Disabled Physical Element Mask 


Translate Address page 299, 300 
DLM. See Disable Loop Master 
DPO 

See Disable Page Out bit 136, 139 

DSA. See Disable Soft Address 
DTFD. See Disable Target Fabric Discovery 
DTIPE. See Disable Target Initiated Port Enable 
DTOLI. See Disable Target Oriented Loop Initialization 


E 


EN_BMS 

Enable Background Medium Scan 389 
Enable Vital Product Data bit 92 
Error Code 

Diagnostic Data Bytes 171 
Error code 

definition 170 
ETF Log Date Code page 481 
ETF Log field 481 
EVPD. See Enable Vital Product Data bit 
Extended bytes from index address descriptor 82 
Extended INQUIRY Data 483 
Extended INQUIRY Data VPD page (86h) 483 
Extended physical sector address descriptor 83 
extended sense 

codes 60 


F 


Factory Log page 330 
Factory log page 330 
Fibre Channel Logical Unit Control mode page 433 
field 
maximum-value 45 
minimum-value 45 
Field Replaceable Unit 
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Diagnostic Data Bytes 171 
Field replaceable unit 170 
Firmware Numbers 488 
Fixed length CDBs 38 

CDB for 10-byte commands 38 

CDB for 12-byte commands 39 

CDB for 6-byte commands 38 

CDB for long LBA 16-byte commands 39 
Format parameters 

page 410 
FORMAT UNIT command 71 
FORMAT UNIT parameter list 75 
FRU. see Field Replaceable Unit 
FUA 

See Force unit access bit 136 


G 


GROUP NUMBER field 139 
Grouping function 44 


Identification Descriptor 491 
illegal request sense key 45 
Information 

Response codes 70h and 71h sense data format 57 
Informational Exceptions Control mode page (1Ch) 415 
INQUIRY command 92 


J 


Jumper Settings 495 
Jumper settings page 495 


K 


Keywords 35 


L 


Log parameters 302 
LOG SELECT command 101 
LOG SENSE command 106 
Logical block address 43 
LOGICAL BLOCK ADDRESS field 139 
LOGICAL BLOCK LENGTH 
Mode Parameter Block Descriptor 382 
Logical Block Provisioning 497 
LUN LIST LENGTH field 180 


M 


maximum-value field 45 

Medium Scan Parameter 315 

minimum-value field 45 

Mode Page Policy 500 

Mode page policy 108 

Mode parameter block descriptor formats 380 
Mode parameter header 378 
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Mode parameters 376 
Caching Parameters page 391 
Control Extension mode page 403 
Control mode page 397 
Disconnect-Reconnect mode page for FCP 405 
Disconnect-Reconnect mode page for SAS 408 
General block descriptor format 380 
MODE DATA LENGTH field 379 
Mode parameter header 378 
Mode parameter header formats 378 
Mode parameter list format 378 
Page_0 Mode page format 384 
Power Condition mode page 422 
Sub_page mode page format 384 
Verify Error Recovery mode page 467 
Mode Select command 45 
MODE SELECT(10) command 110 
MODE SELECT(6) command 108 
MODE SENSE(10) command 114 
MODE SENSE(6) command 111 
PAGE CODE and SUBPAGE CODE fields 111 


NEGOTIATED LOGICAL LINK RATE field 358 
Non-Medium Error log page (06h) 346 
NUMBER OF CYLINDERS 460 

NUMBER OF CYLINDERS field 461 


O 


OPERATION CODE 
CDB 10-byte 38 
CDB 12-byte 39 
CDB 16-byte Long LBA 39 
CDB 32-byte Long LBA 41 
CDB 6-byte 38 
Defined 29 
Description 42 
Values sorted by Command Name 65 
Variable length CDB 40 
OVERWRITE 202 
OVERWRITE service action 202 


P 


PAGE CODE 170 
Page Code 
ASCII Implemented Operating Definition page 482 
Caching Parameters page 391 
Fibre Channel Interface Control page 435 
Rigid Drive Geometry Parameters page 460 
Translate Address page 298, 299, 300 
PAGE CODE and SUBPAGE CODE fields. See Mode Sense (6) com- 
mand 
Page Length 
ETF Log Date Code page 481 
Fibre Channel Interface Control page 435 
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Power Condition page 435 

Translate Address page 298, 299, 300 
Parameter List Length 43 
PARAMETER LIST LENGTH field 103 
Parameter Savable 

Power Condition page 435 
parameter value 

rounding 45 
PC. See Page Control field 101, 102 
PCR 

See Parameter Code Reset 101 
Percentage Used Endurance Indicator log parameter 365 
PERIPHERAL DEVICE TYPE 94 
Peripheral Device Type 

ETF Log Date Code page 481 
PERIPHERAL QUALIFIER 94 

Peripheral Qualifier Description 95 
Peripheral Qualifier 

ETF Log Date Code page 481 
Persistent reservations type 119 
PERSISTENT RESERVE INcommand 115 
Persistent Reserve In command 116 
PERSISTENT RESERVE OUT command 126 
PERSISTENT RESERVE OUT parameter list 128 
PERSISTENT RESERVE OUT service actions 127 
Phy event descriptor 360 
Physical Element Length 

Translate Address page 299, 300 
PLPB. See Prevent Loop Port Bypass 
Port Control Mode page (19h) for Fibre Channel 435 
Power Condition 502 
Power Condition mode page (1Ah) 422 
Power Condition Transitions log page 352, 354, 373 
Power Conditions Vital Product Data page (8Ah) 502 
Power Consumption 504 
Power Consumption Mode page (1Ah/01h) 426 
Power Consumption Vital Product Data page 504 
Power on time parameter 330 
PPC. See Parameter Pointer Control bit 106 
PRESISTANT RESERVE IN command 

PRGENERATION (Persistent Reservations Generation) field 

116 

Prevent Loop Port Bypass 

Fibre Channel Interface Control page 435, 436 
Protocol-specific Port log parameter for SAS 355 


R 


RDPROTECT field 136 
READ BUFFERcommand 144 
READ CAPACITY command 
READ CAPACITY (10) command 155 
READ CAPACITY (16) command 157 
READ Command 
READ (10) command 136 
READ (12) command 140 
READ (16) command 141 
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READ (32)command 142 
READ (6) command 134 
READ DEFECT DATA command 
READ DEFECT DATA (10) command 160 
READ DEFECT DATA (12) command 162 
READ FULL STATUS 123 
READ LONG command 
READ LONG (10) command 164 
READ LONG (16) command _ 166 
READ RESERVATION 117 
READ RETRY COUNT 
Read-Write Error Recovery Mode page 428 
READ RETRY COUNT field 432 
Read-Write Error Recovery mode page 428 
REASSIGN BLOCKS command _ 167 
Rebuild Assist Input diagnostic page 299 
Rebuild Assist Output diagnostic page 300 
RECEIVE DIAGNOSTIC RESULTS command 170, 292 
recovered error sense key 45 
RELEASE command 
RELEASE(10) command 174 
RELEASE(6) command 173 
REPORT CAPABILITIES 120 
REPORT LUNS command 179 
REQUEST SENSE command 195 
RESERVE(10) command 197 
RESERVE(6) command 196 
Retry algorithm 328 
Rezero Unit command 199 
Rigid drive geometry parameters 
page 460 
Rigid Drive Geometry Parameters page 460 
rounded parameter 45 
rounding of parameter values 45 


Ss 
S.M.A.R.T. see Self-Monitoring Analysis and Reporting Technolo- 


gy 
SANITIZE command 200 
SANITIZE service actions 201 
SAS Protocol-Specific Logical Unit mode page 434 
Save Parameters bit 101 
SCSI Enclosure Services pages 298 
SCSI Ports 506 
SCSI Ports VPD page 506 
Seek command 215 
Seek Extended command 216 
Self-monitoring analysis and reporting technology 
measurement 330 
SELF-TEST CODE field 362 
Self-Test Results log page (10h) 361 
SEND DIAGNOSTIC command 217, 292 
Send Diagnostic command 170 
Sense data 46 
SERVICE ACTION field 40, 42 
Solid State Media log page 364, 386, 394, 395, 396, 413, 419 
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Solid State Media log parameters 364, 366 
Stable error correction code syndrome 328 
Standard INQUIRY data 94 

Standard INQUIRY data format 94 
Start-Stop Cycle Counter log page (OEh) 366 
Supported 509 

Supported page/subpage descriptor 370 
Supported Vital Product Data pages 509 
Symbols 33 


T 


Target port Descriptor 508 

Target Port Group Support field 98 
Temperature log page 371 

Temperature log page (ODh) 371 
Temperature log page parameter codes 371 
TPGS. See Target Port Group Support filed 98 
Transfer length 43 

TRANSFER LENGTH field 139 

Translate Address page 295 


U 


Unit Serial Number 510 
Unit Serial Number page 510 
Unrecoverable error 328 


V 


Variable length CDB formats 40 
Typical variable length CDB 40 
Typical variable length CDB for long LBA 32-byte commands 
41 
VENDOR IDENTIFICATION field 99 
Vendor Unique Fault Information 
Diagnostic Data Bytes 171 
VERIFY command 
VERIFY (10) command 234 
VERIFY (12) command 244 
VERIFY (16) command 245 
VERIFY (32) command 246 
Verify Error Recovery mode page 467 
VERSION DESCRIPTOR fields 99 
VERSION field 97 
Vital Product Data 100 
Vital Product Data page 
ASCII Information VDP page 469 
Device Behavior page 482 
Device Identification VPD page 490 
ETF Log Date Code page 481 
Supported Vital Product Data pages 509 
Unit Serial Number page 510 


WwW 


WRITE AND VERIFY command 
262 
WRITE AND VERIFY (10) command 257 
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WRITE AND VERIFY (12) command 258 
WRITE AND VERIFY (16) command 259 
WRITE AND VERIFY (32) command 260 
WRITE ATOMIC (32) command 263 
WRITE BUFFER command 264 
WRITE command 
WRITE (10) command 249 
WRITE (12) command 253 
WRITE (16) command 254 
WRITE (32) command 255 
WRITE (6) command 248 
WRITE LONG command 
WRITE LONG (10) command 273 
WRITE LONG (16) command 274 
WRITE RETRY COUNT 
Read-Write Error Recovery Mode page 428 
WRITE RETRY COUNT field 432 
WRITE STREAM (16) command 280 
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